Javascript的IE和Firefox兼容性汇编---收集篇

js调试工具推荐 firefox 的 firebug 插件
能够给js设置断点执行
能够运行时修改css样式
查看dom模型等

☆ IE8 自带的developer bar也很不错


☆ 打开firefox所有js警告:
在地址栏里录入:about:config
双击,设置 javascript option restict 打开为true 能够看到很多警告,利于纠错

☆ IE -> firefox javascript类
△ document.all("id") -> document.getElementById("id")
并且控件尽量用id,而不是name标识

提示:
如果控件只有name,没有id, 用getElementById时:
IE:也可以找到对象
FF:返回NULL
△ 获得form里某个元素的方法
elForm.elements['name'];

△ 取集合元素时, ie支持 [],() 2种写法, 但是ff仅支持[],如:
table.rows(5).cells(0)
改为:
table.rows[5].cells[0]

△ 判断对象是否是object的方法应该为
if( typeof 对象变量 == "object")
而不是 if(对象变量 == "[object]")

△ eval(对象名称) -> document.getElementById
FF支持eval函数

△ 通过id直接调用对象
对象id.value = ""
改为
document.getElementById("name").value = ""

△ obj.insertAdjacentElement("beforeBegin",objText);
改为用
obj.parentNode.insertBefore(objText,obj);


△ FF的createElement不支持HTML代码
用document.write(esHTML);

或者创建元素后再设置属性, 对input元素来说,需要先设置type再加入到dom里
var ōbj = createElement("input");
obj.type = "checkbox";

var obj2 = document.getElementById("id2");
obj2.parentNode.insertBefore(obj,obj2);

如果是直接插入html代码,则可以考虑用
createContextualFragment


△ innerText -> textContent

△ 对象名称中的$不能识别, 建议改为_
ōbjName = "t1$spin"
改为
ōbjName = "t1_spin"
△ FF里设置Attribute为某个对象,然后再取出来,这时候对象的属性都丢失了?
objText.setAttribute("obj",obj);
alert(obj.id) //正确的名字
obj = objText.getAttribute("obj");
alert(obj.id) //null

在IE下没有问题, FF对setAttribute来说,第2个参数都是字符串型的!!!
所以如果第2个参数是对象时,相当于调用对象的 toString() 方法了

解决的方法是用下面的调用方式:
objText.dropdown_select = obj;

ōbj = objText.dropdown_select


△ className -> class
FF下用class代替IE下的className
由于class是关键字, 所以需要用 setAttribute/getAttribute才行
setAttribute("class","css样式名称");

△ 在html里定义的属性,必须用getAttribute才行

获取时:
document.getElementByID("TD1").isOBJ 总返回 undefined, IE下是可以的
应该用:
document.getElementByID("TD1").getAttribute("isOBJ")


△ FF里select控件不再是:总是在顶端显示
所以可能需要设置控件的zIndex
IE里覆盖select控件的方法是, 用ifame

△ 对于if ( vars == undefined ) 下面的值用于判断是等同的
undefined
null
false
0


△ 如果FF调用obj.focus(); 报错,请尝试改为:
window.setTimeout( function(){ obj.focus(); }, 20);

△ FF下,keyCode是只读的, 那把回车转换为tab怎么办? 在录入时进行键值转换怎么办??

变通的方法是:
1. 回车跳转 -> 自己写跳转处理代码.
遍历dom里所有的元素, 找到当前元素的下一个能够设置焦点的元素, 给其设置焦点

2. 在能够录入的控件里,
把选中的部分替换为新录入的内容: var text = String.fromCharCode(event.keyCode);
同时阻止按键事件上传, 调用: event.preventDefault()


你可能感兴趣的:(JS+AJAX,IE,Firefox,JavaScript,CSS,浏览器,ViewUI)