吴旭晓个人博客 繁体中文 简体中文

首页| 日志 |JAVA |ASP |PHP |Android |IOS |ASP.NET |JavaScript |DIV+CSS |SEO |taobaoke |饼哥语录
繁体中文 简体中文

小心IE 下document.getElementById()的陷阱

document.getElementById() 方法,我们都很熟悉的,这个方法可以使用一个元素的 ID 获取这个元素的 DOM 对象。W3C规定这个方法只能以 ID 为参数,但是 MSDN 中对此方法的定义确是返回第一个 ID 或 name 为参数的 DOM 与元素。看,MSDN里的说明:http://msdn.microsoft.com/en-us/library/ms536437(VS.85).aspx

因为这个差异,会造成这个方法的兼容性问题。当使用元素的 name 获取元素对象的时候,就会产生这个问题,IE支持,Safari 和 Chrome 等都不支持。

请看下面的代码:
HTML code
<input type="button" id="inputid" name="inputname" value="test"> <script>     window.onload = function() {           alert(document.getElementById("inputname"));     } </script>

上面这段代码中,使用了 INPUT 元素的name属性来获取它的DOM元素。

这段代码在IE6(S)(Q) 、IE7(Q)(S)和IE8(Q)中,都返回一个 object类型的对象。但是在其他浏览器中返回一个 null。

有兴趣的同学可以尝试把 INPUT 元素换成其他类型的元素试试,这个问题还可能跟类型有关系呢。

为了避免这个兼容性问题,以免造成功能性问题,最好使用 ID 作为该方法的参数。

作者:吴旭晓 | 来源:个人博客 | 点击量:2601 | 发布时间:2010-09-03
最新留言 | 返回上一页 | 返回首页

相关文章:

版权所有:吴旭晓个人博客 Copyright © 2013-2023 个人博客