各瀏覽器對(duì)document.getElementById等方法的實(shí)現(xiàn)差異解析
所有Web前端同仁對(duì) document.getElementById 都非常熟悉了。開發(fā)過程中經(jīng)常需要用其獲取頁(yè)面id為xx的元素,自從元老級(jí)JS庫(kù)Prototype流行后,都喜歡這么簡(jiǎn)寫它
// 方式1
function $(id){ return document.getElementById(id); }
有沒有人想過為什么要這么寫,而不用下面的方式寫呢?
// 方式2
var $ = document.getElementById;
這么寫的$更簡(jiǎn)潔啊,也很明了,將document的方法getElementById賦值給變量$,用$去獲取頁(yè)面id為xx的元素。實(shí)際上方式2在IE6/7/8中是可行的(IE9中有些變動(dòng)),F(xiàn)irefox/Safari/Chrome/Opera則行不通。還請(qǐng)自行測(cè)試。
為什么Firefox/Safari/Chrome/Opera 方式2獲取就不行呢,原因是這些瀏覽器中g(shù)etElementById方法內(nèi)部實(shí)現(xiàn)中需依賴this(document),IE則不需要this。或者說方式2在Firefox/Safari/Chrome/Opera中調(diào)用時(shí)說丟失了this,以下是個(gè)簡(jiǎn)單示例
// 定義一個(gè)函數(shù)show
function show(){alert(this.name);}
// 定義一個(gè)p對(duì)象,有name屬性
var p = {name:'Jack'};
show.call(p); // -> 'Jack'
show(); // -> ''
show.call(null); // -> ''<BR>
可以看到show的實(shí)現(xiàn)中依賴this(簡(jiǎn)單說方法體中使用了this),因此調(diào)用時(shí)的環(huán)境(執(zhí)行上下文)如果沒有name屬性,則得不到期望的結(jié)果。
換句話說,IE6/7/8實(shí)現(xiàn)document.getElementById時(shí)沒有用到this,而 IE9/Firefox/Safari/Chrome/Opera 需要用到this,這里的this正是document對(duì)象。直接調(diào)用方式2時(shí)內(nèi)部的 this卻是window對(duì)象,所以造成方式2在 Firefox/Safari/Chrome/Opera 不能根據(jù)id來正常獲取元素。
如果將document.getElementById的 執(zhí)行環(huán)境換成了document而非window,則可以正常的使用$了。如下
// 修復(fù)document.getElementById
document.getElementById = (function(fn){
return function(){
return fn.apply(document,arguments);
};
})(document.getElementById);
// 修復(fù)后賦值給$,$可正常使用了
var $ = document.getElementById;
再次,ECMAScript5 中為function新增的 bind 方法可以實(shí)現(xiàn)同樣的效果
// 方式3
var $ = document.getElementById.bind(document);
但目前方式3只有IE9/Firefox/Chrome/支持。
分析了getElementById的情況,下面的一些方法在各瀏覽器中的差異原因就很好明白了
var prinf = document.write;
prinf('<h3>Test prinf</h3>'); // IE6/7/8可運(yùn)行,其它瀏覽器報(bào)錯(cuò)
var prinfln = document.writeln;
prinfln('<h3>Test prinfln</h3>'); // IE6/7/8可運(yùn)行,其它瀏覽器報(bào)錯(cuò)
var reload = location.reload;
reload(); // IE6/7/8可運(yùn)行,其它瀏覽器報(bào)錯(cuò)
var go = history.go;
go(-2); // IE6/7/8可運(yùn)行,其它瀏覽器報(bào)錯(cuò)
- document.getElementById獲取控件對(duì)象為空的解決方法
- js中document.getElementByid、document.all和document.layers區(qū)分介紹
- document.getElementById介紹
- jquery中的 $("#jb51")與document.getElementById("jb51") 的區(qū)別
- document.getElementById的簡(jiǎn)寫方式(獲取id對(duì)象的簡(jiǎn)略寫法)
- document.getElementById方法在Firefox與IE中的區(qū)別
- document.getElementById為空或不是對(duì)象的解決方法
相關(guān)文章
Bootstrap響應(yīng)式側(cè)邊欄改進(jìn)版
這篇文章主要為大家詳細(xì)介紹了Bootstrap響應(yīng)式側(cè)邊欄改進(jìn)版,結(jié)合導(dǎo)航條和下拉菜單進(jìn)行改進(jìn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09再次更新!MSClass (Class Of Marquee Scroll通用不間斷滾動(dòng)JS封裝類 Ver 1.6)
再次更新!MSClass (Class Of Marquee Scroll通用不間斷滾動(dòng)JS封裝類 Ver 1.6)...2007-02-02關(guān)于JavaScript中的this指向問題總結(jié)篇
在小編面試過程中經(jīng)常會(huì)遇到j(luò)avascript中this指向問題,可以說是前端面試必問,下面小編給大家總結(jié)了一下js中this的指向,感興趣的朋友一起學(xué)習(xí)吧2017-07-07使用javascript實(shí)現(xiàn)簡(jiǎn)單的選項(xiàng)卡切換
本文主要介紹了使用javascript實(shí)現(xiàn)簡(jiǎn)單的選項(xiàng)卡切換的效果,代碼非常的簡(jiǎn)單,兼容性十分棒,這里推薦給小伙伴們。2015-01-01