文档库 最新最全的文档下载
当前位置:文档库 › Javascript 多浏览器兼容性问题及解决方案

Javascript 多浏览器兼容性问题及解决方案

Javascript 多浏览器兼容性问题及解决方案
Javascript 多浏览器兼容性问题及解决方案

Javascript 多浏览器兼容性问题及解决方案

一、document.formName.item(”itemName”) 问题

问题说明:IE下,可以使用document.formName.item(”itemName”) 或document.formName.elements ["elementName"];Firefox 下,只能使用document.formName.elements["elementName"]。

解决方法:统一使用document.formName.elements["elementName"]。

二、集合类对象问题

问题说明:IE下,可以使用() 或[] 获取集合类对象;Firefox下,只能使用[ ]获取集合类对象。

解决方法:统一使用[] 获取集合类对象。

三、自定义属性问题

问题说明:IE下,可以使用获取常规属性的方法来获取自定义属性,也可以使用getAttribute() 获取自定义属性;Firefox下,只能使用getAttribute() 获取自定义属性。

解决方法:统一通过getAttribute() 获取自定义属性。

四、eval(”idName”)问题

问题说明:IE下,可以使用eval(”idName”) 或getElementById(”idName”) 来取得id 为idName 的HTML对象;Firefox下,只能使用getElementById(”idName”) 来取得id 为idName 的HTML对象。

解决方法:统一用getElementById(”idName”) 来取得id 为idName 的HTML对象。

五、变量名与某HTML对象ID相同的问题

问题说明:IE下,HTML对象的ID可以作为document 的下属对象变量名直接使用,Firefox 下则不能;Firefox下,可以使用与HTML对象ID相同的变量名,IE下则不能。

解决方法:使用document.getElementById(”idName”) 代替document.idName。最好不要取HTML对象ID相同的变量名,以减少错误;在声明变量时,一律加上var关键字,以避免歧义。

六、const问题

问题说明:Firefox下,可以使用const关键字或var关键字来定义常量;IE下,只能使用var 关键字来定义常量。

解决方法:统一使用var关键字来定义常量。

七、input.type属性问题

问题说明:IE下input.type 属性为只读;但是Firefox下input.type 属性为读写。

解决办法:不修改input.type 属性。如果必须要修改,可以先隐藏原来的input,然后在同样的位置再插入一个新的input元素。

八、window.event问题

问题说明:window.event 只能在IE下运行,而不能在Firefox下运行,这是因为Firefox的event只能在事件发生的现场使用。

解决方法:在事件发生的函数上加上event参数,在函数体内(假设形参为evt)使用var myEvent = evt?evt:(window.event?window.event:null)

示例: