IE和Firefox的js兼容性整理(2)
作者:zt 来源:老猫的理想 时间:2007-11-21 19:40:00
变量名与某 HTML 对象 id 相同的问题
(1)现有问题:在 MF 中,因为对象 id 不作为 HTML 对象的名称,所以可以使用与 HTML 对象 id 相同的变量名,IE 中不能。
(2)解决方法:在声明变量时,一律加上 var ,以避免歧义,这样在 IE 中亦可正常运行。
此外,最好不要取与 HTML 对象 id 相同的变量名,以减少错误。
(3)其它:参见 问题4
event.x 与 event.y 问题
(1)现有问题:在IE 中,event 对象有 x, y 属性,MF中没有。
(2)解决方法:在MF中,与event.x 等效的是 event.pageX。但event.pageX IE中没有。
故采用 event.clientX 代替 event.x。在IE 中也有这个变量。vent.clientX 与 event.pageX 有微妙的差别(当整个页面有滚动条的时候),不过大多数时候是等效的。
如果要完全一样,可以稍麻烦些:
mX = event.x ? event.x : event.pageX;
然后用 mX 代替 event.x
(3)其它:event.layerX 在 IE 与 MF 中都有,具体意义有无差别尚未试验。
关于frame
(1)现有问题:在 IE中 可以用window.testFrame取得该frame,mf中不行
(2)解决方法:在frame的使用方面mf和ie的最主要的区别是:如果在frame标签中书写了以下属性:
<frame src="/blog/xx.htm" id="frameId" name="frameName" />
那么ie可以通过id或者name访问这个frame对应的window对象而mf只可以通过name来访问这个frame对应的window对象。例如如果上述frame标签写在最上层的window里面的htm里面,那么可以这样访问。
ie: window.top.frameId或者window.top.frameName来访问这个window对象;
mf: 只能这样window.top.frameName来访问这个window对象
另外,在mf和ie中都可以使用window.top.document.getElementById("frameId")来访问frame标签,并且可以通过window.top.document.getElementById("testFrame").src = ’xx.htm’来切换frame的内容,也都可以通过window.top.frameName.location = ’xx.htm’来切换frame的内容
关于frame和window的描述可以参见bbs的‘window与frame’文章,以及 /test/js/test_frame/ 目录下面的测试----adun 2004.12.09修改
在mf中,自己定义的属性必须getAttribute()取得,在mf中没有 parentElement parement.children 而用parentNode parentNode.childNodes
childNodes的下标的含义在IE和MF中不同,MF使用DOM规范,childNodes中会插入空白文本节点。一般可以通过node.getElementsByTagName()来回避这个问题。
当html中节点缺失时,IE和MF对parentNode的解释不同,例如
<form>
<table>
<input/>
</table>
</form>
MF中input.parentNode的值为form, 而IE中input.parentNode的值为空节点
MF中节点没有removeNode方法,必须使用如下方法 node.parentNode.removeChild(node)