日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

各浏览器对document.getElementById等方法的实现差异

發布時間:2025/5/22 HTML 132 豆豆
生活随笔 收集整理的這篇文章主要介紹了 各浏览器对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。或者說方式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,則可以正常的使用$了。如下

// 修復document.getElementById document.getElementById = (function(fn){return function(){ return fn.apply(document,arguments);}; })(document.getElementById);// 修復后賦值給$,$可正常使用了 var $ = document.getElementById;

再次,ECMAScript5 中為function新增的 bind 方法可以實現同樣的效果

// 方式3 var $ = document.getElementById.bind(document);

但目前方式3只有IE9/Firefox/Chrome/支持。

分析了getElementById的情況,下面的一些方法在各瀏覽器中的差異原因就很好明白了

var prinf = document.write; prinf('<h3>Test prinf</h3>'); // IE6/7/8可運行,其它瀏覽器報錯var prinfln = document.writeln; prinfln('<h3>Test prinfln</h3>'); // IE6/7/8可運行,其它瀏覽器報錯var reload = location.reload; reload(); // IE6/7/8可運行,其它瀏覽器報錯var go = history.go; go(-2); // IE6/7/8可運行,其它瀏覽器報錯

轉自:?http://www.cnblogs.com/snandy/archive/2011/03/24/1993380.html

轉載于:https://www.cnblogs.com/likebeta/archive/2012/05/04/2483455.html

總結

以上是生活随笔為你收集整理的各浏览器对document.getElementById等方法的实现差异的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美精品在线播放 | 夜夜嗨av一区二区三区 | 欧美成综合| 色婷婷久久一区二区三区麻豆 | 国产精品福利一区二区三区 | 怡红院一区二区三区 | 最近中文字幕在线视频 | 精品黄色片 | 奇米在线777 | 麻豆午夜视频 | 国产免费a级片 | a v视频在线观看 | 色女孩综合网 | av在线男人天堂 | 国产视频三区 | 小色瓷导航 | 欧美特一级片 | 丁香九月婷婷 | 小黄网站在线观看 | 毛片基地站 | 天天搞夜夜爽 | 麻豆av一区二区三区久久 | 性欧美在线观看 | 日韩淫片| 日本一级片在线播放 | 中文字幕亚洲乱码熟女1区2区 | 久久精品不卡 | 亚洲九九九九 | 色一区二区三区四区 | 91精品国产一区二区在线观看 | 日日操夜夜操视频 | 人妻丰满熟妇aⅴ无码 | 国产黄大片在线观看画质优化 | 樱花草涩涩www在线播放 | 亚洲精品久久久久久无码色欲四季 | 免费看黄色片网站 | 熟睡侵犯の奶水授乳在线 | 污视频网站免费 | 精品一区免费 | a天堂在线| 国模在线视频 | 欧美激情成人 | 久久免费福利 | 青草视频免费观看 | 91av影院 | 光溜溜视频素材大全美女 | 乱色精品无码一区二区国产盗 | 成人黄色大片在线观看 | 成人亚洲精品久久久久软件 | 在线播放成人av | 色中文网 | 影音先锋日韩资源 | www.97超碰| 天天干天天添 | 伊人婷婷色| 69福利社区 | 国产精品爽爽爽 | 天堂久久网 | 在线观看免费国产视频 | 大毛片| 一二三在线视频 | 狠狠操影视| 日韩三区在线 | 操校花视频 | 久久午夜无码鲁丝片 | 91精品久久人妻一区二区夜夜夜 | 中文字幕中文在线 | 欧美亚洲三级 | 日本色中色 | 午夜dv内射一区二区 | av免费网站在线观看 | 久久久亚洲国产精品 | 在线你懂得 | 成年人一级片 | 欧美最猛黑人xxxx黑人猛交 | 日本精品一区二区三区在线观看 | 亚洲日本在线观看 | 欧美在线免费视频 | 日本精品网站 | 啪啪中文字幕 | 青青青青青青青青草 | 欧美成一区二区三区 | 91免费视 | 国产污视频在线 | 中国二级毛片 | 午夜影院欧美 | 日本人视频69式jzzij | 国产97免费视频 | 欧美一区二区久久 | www99re| 国产一区二区三区视频 | 直接看毛片| aaa级片 | 可以免费看的毛片 | 韩国女主播av | 欧美日韩一区二区三区不卡 | 日韩欧美国产一区二区 | 日韩人妻精品中文字幕 | 精品韩国一区二区三区 |