各浏览器对document.getElementById等方法的实现差异
所有Web前端同仁對 document.getElementById 都非常熟悉了。開發過程中經常需要用其獲取頁面id為xx的元素,自從元老級JS庫Prototype流行后,都喜歡這么簡寫它
// 方式1 function $(id){ return document.getElementById(id); }有沒有人想過為什么要這么寫,而不用下面的方式寫呢?
// 方式2 var $ = document.getElementById;這么寫的$更簡潔啊,也很明了,將document的方法getElementById賦值給變量$,用$去獲取頁面id為xx的元素。實際上方式2在IE6/7/8中是可行的(IE9中有些變動),Firefox/Safari/Chrome/Opera則行不通。還請自行測試。
為什么Firefox/Safari/Chrome/Opera 方式2獲取就不行呢,原因是這些瀏覽器中getElementById方法內部實現中需依賴this(document),IE則不需要this?;蛘哒f方式2在Firefox/Safari/Chrome/Opera中調用時說丟失了this,以下是個簡單示例
可以看到show的實現中依賴this(簡單說方法體中使用了this),因此調用時的環境(執行上下文)如果沒有name屬性,則得不到期望的結果。
換句話說,IE6/7/8實現document.getElementById時沒有用到this,而 IE9/Firefox/Safari/Chrome/Opera 需要用到this,這里的this正是document對象。直接調用方式2時內部的 this卻是window對象,所以造成方式2在 Firefox/Safari/Chrome/Opera 不能根據id來正常獲取元素。
如果將document.getElementById的 執行環境換成了document而非window,則可以正常的使用$了。如下
再次,ECMAScript5 中為function新增的 bind 方法可以實現同樣的效果
// 方式3 var $ = document.getElementById.bind(document);但目前方式3只有IE9/Firefox/Chrome/支持。
分析了getElementById的情況,下面的一些方法在各瀏覽器中的差異原因就很好明白了
轉自:?http://www.cnblogs.com/snandy/archive/2011/03/24/1993380.html
轉載于:https://www.cnblogs.com/likebeta/archive/2012/05/04/2483455.html
總結
以上是生活随笔為你收集整理的各浏览器对document.getElementById等方法的实现差异的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: PHP笔试题——处理大文件(最简单的方法
- 下一篇: AE 各分析适用数据