IE 中一個對象的 native 方法是跟該對象綁定的
來源:易賢網 閱讀:1219 次 日期:2015-04-22 11:12:08
溫馨提示:易賢網小編為您整理了“IE 中一個對象的 native 方法是跟該對象綁定的”,方便廣大網友查閱!

問題描述

在 IE 中將一個 DOM 或 BOM 對象的原生方法賦給一個變量后,該變量可以成功調用。

造成的影響

在非 IE 瀏覽器中可能導致腳本異常,停止解析。

受影響的瀏覽器

IE

問題分析

這里使用 document.getElementById 來說明問題。

在前端開發過程中經常需要使用 document.getElementById 來獲取頁面中含有 id 屬性 DOM 元素,為了方便,該方法經常被簡寫,如下:

//方式1

var $1 = function(id){return document.getElementById(id);};

//方式2

var $2 = document.getElementById;

用縮寫的 $1、$2 測試,代碼如下:

<!DOCTYPE html>

<html>

<head>

</head>

<body>

<div id="d1">Div Element</div>

<script type="text/javascript">

var $1 = function(id){return document.getElementById(id);};

var $2 = document.getElementById;

alert($1('d1'));

alert($2('d1'));

</script>

</body>

</html>

各瀏覽器中表現如下:1

函數名IEFirefox Safari Chrome Opera

$1OKOK

$2OKFAIL

注1:OK 表示可以獲取 DIV 元素,FAIL 表示不能獲取 DIV 元素,控制臺出錯。

方式 1 在所有瀏覽器中均有效,而方式 2 僅在 IE 瀏覽器中有效。相同的效果也發生在 document 對象的其他方法上, 甚至是 location、history 等 BOM 對象的方法上。如:

//方式1

var println1 = function(str){document.writeln(str);};

//方式2 (僅IE)

var println2 = document.writeln;

//JS

println2('<h1>Hello,world.</h1>');

IE 下方式 2 在 DOM 或 BOM 對象的原生函數賦值給其他變量時會自動將其綁定到在 DOM 或 BOM 對象上, 而非 IE 瀏覽器(Firefox Safari Chrome Opera)需要用到 this,這里的 this 是 document 對象。 直接調用 $2() 時內部的 this 卻是 window 對象,所以造成 $2() 不能根據 id 來正常獲取元素。

如果將 document.getElementById 的執行環境換成了 document ,則可以正常的使用 $2 了,如下:

document.getElementById = (function(fn){

return function(){

return fn.apply(document,arguments);

};

})(document.getElementById);

var $2 = document.getElementById;

解決方案

使用方式 1 達到簡寫一些 DOM 和 BOM 對象原生方法的目的。

更多信息請查看IT技術專欄

更多信息請查看腳本欄目
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
未满十八18勿进黄网站免费看