Javascript无法在FF上工作

Cod*_*x73 1 javascript ajax firefox javascript-events

我有以下代码,在IE中为textarea元素工作完美.

(编辑:为了可读性而包装)

<textarea name="mem_message" cols="25" rows="5"
  onkeypress="return taLimit(this)" 
  onkeyup="return taCount(this,'myCounter')">
    <? echo $_SESSION['mem_message']; ?>
</textarea>
Run Code Online (Sandbox Code Playgroud)

它调用验证函数:

<script language="Javascript"><!--Counter for Message Box -->

maxL=100;
var bName = navigator.appName;
function taLimit(taObj) {
    if (taObj.value.length==maxL) return false;
    return true;
}

function taCount(taObj,Cnt) { 
    objCnt=createObject(Cnt);
    objVal=taObj.value;
    if (objVal.length>maxL) objVal=objVal.substring(0,maxL);
    if (objCnt) {
        if(bName == "Netscape"){    
            objCnt.textContent=maxL-objVal.length;}
        else{objCnt.innerText=maxL-objVal.length;}
    }
    return true;
}
function createObject(objId) {
    if (document.getElementById) return document.getElementById(objId);
    else if (document.layers) return eval("document." + objId);
    else if (document.all) return eval("document.all." + objId);
    else return eval("document." + objId);
}
</script>
Run Code Online (Sandbox Code Playgroud)

以上所有内容仅适用于IE.在Firefox上它甚至不会专注于盒子.

kan*_*gax 10

几个指针:

  • 不要使用language ="javascript",它已被弃用.
  • 不要eval用于财产访问,这是缓慢和不必要的.
  • 不要嗅探"Netscape",而是检查属性/方法是否存在/合规性(innerText/textContent)
  • 不要将接收元素的方法命名为"createObject",这会产生误导.
  • 不执行未声明的赋值(maxL = 100),它容易出错.
  • 对于约定,不要将非构造函数(或名称空间)的变量名称大写.
  • 尽量不要在全局范围内声明函数,以避免名称冲突.

  • 实际上"TJ Crowder"问题是通过实现"Kangax"第一个指针并简单地将脚本选项更改为type ="text/javascript"来解决的.好好工作.如果你没有帮助,请不要诋毁贡献者,反而学习.谢谢"Kangar"! (2认同)