首頁 >web前端 >js教程 >各瀏覽器對document.getElementById等方法的實作差異解析_javascript技巧

各瀏覽器對document.getElementById等方法的實作差異解析_javascript技巧

WBOY
WBOY原創
2016-05-16 17:10:361096瀏覽

所有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。或者說方式2在Firefox/Safari/Chrome/Opera中調用時說丟失了this,以下是個簡單示例

複製代碼程式碼如下:

// 定義一個函數show
function show(){alert(this.name);}

// 定義一個p對象,有name屬性
var p = {name:'Jack'};

show.call(p); // -> 'Jack'
show(); // -> ''
show.call(null); // -> ''


可以看到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,則可以正常的使用$了。如下

複製程式碼


程式碼如下:


// 修補程式.getElementBy. getElementById = (function(fn){
    return function(){ 
        return fn.apply(document,arguments);
   return fn.apply(document,arguments);
   return fn.apply(document,arguments);
   return fn.apply(document,arguments);
   return fn.apply(document,arguments); >// 修復後賦值給$,$可正常使用了
var $ = document.getElementById; 複製程式碼


程式碼如下:

// 方式3 varget = docum. .bind(document);


複製程式碼



複製程式碼


程式碼如下:


var prinf = document.write;
prinf('

Test prinf

'); // IE6/7/8可運行,其它瀏覽器報錯

var prinfln = document.writeln;
prinfln('

Test prinfln

'); // IE6/7/8可運行,其它瀏覽器報錯var reload = location.reload; reload(); // IE6/7/8可運行,其它瀏覽器報錯var go = history.go;  go( -2); // IE6/7/8可運行,其它瀏覽器報錯
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn