JavaScript:计算文本中字符的最小长度,忽略其中的特殊代码

时间:2010-04-07 15:09:21

标签: javascript count special-characters

如果textarea中有特殊代码,我想忽略计算文本中字符的长度。我的意思是不计算文本中的特殊代码字符。我使用特殊代码来定义文本中的输入表情。我想只计算忽略特殊代码的文本长度。

这是我尝试编写的近似代码,但不能让它起作用:

// smileys
// =======

function smileys(){

var smile = new Array();

smile[0]  = "[:rolleyes:]";
smile[1]  = "[:D]";
smile[2]  = "[:blink:]";
smile[3]  = "[:unsure:]";
smile[4]  = "[8)]";
smile[5]  = "[:-x]";

return(smile);
}

// symbols length limitation
// =========================

function minSymbols(field){

var get_smile = smileys();
var text = field.value;

for(var i=0; i<get_smile.length; i++){
for(var j=0; j<(text.length); j++){
if(get_smile[i]==text[j]){
text = field.value.replace(get_smile[i],"");
}
}
}

if(text.length < 50){
document.getElementById("saveB").disabled=true;
} else {
document.getElementById("saveB").disabled=false;
}
}

脚本应该如何让它工作?谢谢!

3 个答案:

答案 0 :(得分:2)

我首先要改变我定义表情符号的方式:

var smilies = [
    {text: "[:rolleyes:]", exp: /\[\:rolleyes\:\]/g},
    {text: "[:D]",         exp: /\[\:D\]/g},
    {text: "[:blink:]",    exp: /\[\:blink\:\]/g},
    {text: "[:unsure:]",   exp: /\[\:unsure\:\]/g},
    {text: "[8)]",         exp: /\[8\)\]/g},
    {text: "[:-x]",        exp: /\[\:-x\]/g}
];

(我没有立即看到任何原因这必须是一个函数,但如果你愿意,你可以把它作为一个。)这是一个对象数组,每个对象都有一个带有笑脸文本的text属性和一个exp对象,其RegExp与之匹配(设置全局标志)。

然后该函数看起来有点像这样:

function getLengthMinusSmilies(field) {
    var text, index, length, smiley;

    text = field.value;
    length = text.length;
    for (index = 0; index < smilies.length; ++index) {
        smiley = smilies[index];
        while (smiley.exp.test(text)) {
            length -= smiley.text.length;
        }
    }
    return length;
}

这可以避免创建和丢弃临时字符串。它只计算表情符号的匹配并忽略它们的长度。

您不必使用textexp值的对象,如果您愿意,可以使用并行数组:

var smilies = [
    "[:rolleyes:]",
    "[:D]",
    "[:blink:]",
    "[:unsure:]",
    "[8)]",
    "[:-x]"
];

var matchExps = [
    /\[\:rolleyes\:\]/g,
    /\[\:D\]/g,
    /\[\:blink\:\]/g,
    /\[\:unsure\:\]/g,
    /\[8\)\]/g,
    /\[\:-x\]/g
];

...然后相应地调整函数中的循环。使用一个带有对象的数组往往更易于维护,但如果你需要在其他地方使用数组......

答案 1 :(得分:1)

function minSymbols(field){
    var get_smile = smileys();
    var text = field.value;

    for(var i=0; i<get_smile.length; i++){
        text = text.replace(get_smile[i],"");
    }
}

答案 2 :(得分:0)

function getTxtLen()
{
    var str=document.getElementById('myTxtBox').value;

        str=str.replace(/\[:some:\]/g,'');
        str=str.replace(/\[:some2:\]/g,'');

        alert(str.length);
}