成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

兼容所有瀏覽器的DOM擴(kuò)展功能

開發(fā) 前端
技術(shù)文章寫得少,所以有時候想寫點什么卻下不了手,不知道該寫什么;往往到了準(zhǔn)備要寫的時候才發(fā)現(xiàn)自己想寫的東西其實很無聊,甚至覺得很幼稚,于是又關(guān)掉了編緝器,呵呵。

技術(shù)文章寫得少,所以有時候想寫點什么卻下不了手,不知道該寫什么;往往到了準(zhǔn)備要寫的時候才發(fā)現(xiàn)自己想寫的東西其實很無聊,甚至覺得很幼稚,于是又關(guān)掉了編緝器,呵呵。

今天周五,很閑,坐在電腦前沒什么事可做,產(chǎn)品線的人也沒提什么新的需求,可能下周會有新的需求和工作安排,但那是下周的事了。今天就想寫點技術(shù)的東西,也就當(dāng)作是記記筆記,本人水平有限,希望大家多多指教,嘴下留情,哈哈。

有時候我們會想擴(kuò)展DOM元素的功能,可以添加一些自定義的方法,以讓它用起來更加靈活、方便;先來舉個例子:

  1. <!DOCTYPE html> 
  2. <html lang="zh"> 
  3.  <head> 
  4.   <title>DOM功能擴(kuò)展</title> 
  5.  </head> 
  6.  <body> 
  7.     <a href="javascript:void(0)" id="tagA">你好</a> 
  8.     <script type="text/javascript"> 
  9.     <!--  
  10.         var tagA=document.getElementById("tagA");  
  11.         tagA.onclick=function(){  
  12.             alert(this.innerHTML);  
  13.         }  
  14.     //--> 
  15.     </script> 
  16.  </body> 
  17. </html> 

毫無疑問,從以上代碼可以看出,當(dāng)點擊A標(biāo)簽的時候會彈出“你好”,tagA是一個DOM元素,除了有onclick事件以外,還有onmouseover,onmouseout,onmousemove等等,而這些事件都是DOM元素本身就具有的;但現(xiàn)在我們希望對它進(jìn)行擴(kuò)展,例如可以讓它支持tagA.bind,我可以用tagA.bind("click",function(){}),來代替tagA.onclick=function(){}。OK,現(xiàn)在的目的很明確,先看下面的代碼:

  1. <!DOCTYPE html> 
  2. <html lang="zh"> 
  3.  <head> 
  4.   <title>DOM功能擴(kuò)展</title> 
  5.  </head> 
  6.  <body> 
  7.     <a href="javascript:void(0)" id="tagA">你好</a> 
  8.     <script type="text/javascript"> 
  9.     <!--  
  10.         var tagA=document.getElementById("tagA");  
  11.         tagA.bind("click",function(){  
  12.             alert(this.innerHTML);  
  13.         })  
  14.     //--> 
  15.     </script> 
  16.  </body> 
  17. </html> 

以上這段代碼就是功能擴(kuò)展后的最終效果,它與上一段代碼實現(xiàn)的功能是一樣的,但現(xiàn)在它還不能執(zhí)行,要進(jìn)行擴(kuò)展后才可以,在此之前先來看一些基礎(chǔ)知識,這很重要,因為等下會用到:

  1、HTMLElement,在DOM標(biāo)準(zhǔn)中,每個元素都繼承自HTMLElement,而HTMLElement又繼承自Element,Element又繼承自Node;于是我們可以使用HTMLElement的Prototype來擴(kuò)展HTML元素的方法和屬性,如何實現(xiàn)?我們來看一段代碼:

  1. <!DOCTYPE html> 
  2. <html lang="zh"> 
  3.  <head> 
  4.   <title>DOM功能擴(kuò)展</title> 
  5.  </head> 
  6.  <body> 
  7.     <a href="javascript:void(0)" id="tagA">你好</a> 
  8.     <script type="text/javascript"> 
  9.     <!--  
  10.     HTMLElement.prototype.Alert=function(){  
  11.         alert("這是一個擴(kuò)展方法");  
  12.     }  
  13.     var tagA=document.getElementById("tagA");  
  14.     tagA.Alert();  
  15.     //--> 
  16.     </script> 
  17.  </body> 
  18. </html> 

以上代碼在頁面加載的時候就彈出“這是一個擴(kuò)展方法”,不過相信你已經(jīng)注意到了,在IE6,7,8里面會出錯,但在IE9以上或者Chrome,Firefox,Opera這些瀏覽器里面都能正常運行,這是兼容性問題,不用擔(dān)心,后面會解決。

以上的代碼靈活性不夠好,我們優(yōu)化一下,讓它更加靈活:

  1. <!DOCTYPE html> 
  2. <html lang="zh"> 
  3.  <head> 
  4.   <title>DOM功能擴(kuò)展</title> 
  5.  </head> 
  6.  <body> 
  7.     <a href="javascript:void(0)" id="tagA">你好</a> 
  8.     <script type="text/javascript"> 
  9.     <!--  
  10.         function DOMExtend(name,fn){  
  11.             eval("HTMLElement.prototype."+name+"="+fn);//這里我們采用動態(tài)擴(kuò)展  
  12.         }  
  13.         function Alert(){  
  14.             alert("這是一個擴(kuò)展方法");  
  15.         }  
  16.         DOMExtend("Alert",Alert);  
  17.  
  18.         var tagA=document.getElementById("tagA");  
  19.         tagA.Alert();  
  20.     //--> 
  21.     </script> 
  22.  </body> 
  23. </html> 

從以上代碼可以看出,有了DOMExtend這個方法以后,我們就可以通過傳入不用的name 和 fn 實現(xiàn)不同的擴(kuò)展。

2、以上講完了HTMLElement,接下來講講事件的綁定,很多人都知道,IE和其他瀏覽器的事件綁定方式不一樣,實現(xiàn)兼容所有瀏覽器的事件綁定的代碼如下:

  1. function BindEvent(elem,event,fun){  
  2.     if(elem.addEventListener){  
  3.         elem.addEventListener(event,fun,false);  
  4.     }  
  5.     else{  
  6.         elem.attachEvent("on"+event,fun);  
  7.     }  

以下是事件綁定的使用例子:

  1. <!DOCTYPE html> 
  2. <html lang="zh"> 
  3.  <head> 
  4.   <title>DOM功能擴(kuò)展</title> 
  5.  </head> 
  6.  <body> 
  7.     <a href="javascript:void(0)" id="tagA">你好</a> 
  8.     <script type="text/javascript"> 
  9.     <!--  
  10.         function BindEvent(elem,event,fun){  
  11.             if(elem.addEventListener){  
  12.                 elem.addEventListener(event,fun,false);  
  13.             }  
  14.             else{  
  15.                 elem.attachEvent("on"+event,fun);  
  16.             }  
  17.         }  
  18.         var tagA=document.getElementById("tagA");  
  19.         function Alert(){  
  20.             alert("這是事件綁定");  
  21.         }  
  22.         BindEvent(tagA,"click",Alert);  
  23.     //--> 
  24.     </script> 
  25.  </body> 
  26. </html> 

以上代碼運行后,點擊“你好”就會彈出“這是事件綁定”,這里值得一提的就是addEvenListener的第三個參數(shù),這里的值是false,意思是取消Capture方式而采用冒泡方式。標(biāo)準(zhǔn)的事件有兩種觸發(fā)方式,一種是捕獲型(caputre),另一種是冒泡型;而IE只支持冒泡型。捕獲型的特點是觸發(fā)方式是從外到內(nèi)的方式觸發(fā)事件,而冒泡型就是從內(nèi)到外的方式觸發(fā)事件,假設(shè)以上代碼的A元素外層包了一個DIV元素,如果A元素與它的父元素DIV都有一個onclick事件,那么冒泡型就是點擊A的時候會先觸發(fā)A的事件,然后再觸發(fā)DIV的事件,反之就是捕獲型。

OK,相信通過以上的分析,對HTMLElement擴(kuò)展和事件綁定都有了相當(dāng)?shù)牧私猓Y(jié)合這兩個知識點,我們可以寫出如下的代碼:

  1. <!DOCTYPE html> 
  2. <html lang="zh"> 
  3.  <head> 
  4.   <title>DOM功能擴(kuò)展</title> 
  5.  </head> 
  6.  <body> 
  7.     <a href="javascript:void(0)" id="tagA">你好</a> 
  8.     <script type="text/javascript"> 
  9.     <!--  
  10.         function DOMExtend(name,fn){  
  11.             eval("HTMLElement.prototype."+name+"="+fn);//這里我們采用動態(tài)擴(kuò)展  
  12.         }  
  13.  
  14.         function BindEvent(event,fun){  
  15.             if(this.addEventListener){//執(zhí)行完DOMExtend后,這里的this會指向HTMLElement  
  16.                 this.addEventListener(event,fun,false);//標(biāo)準(zhǔn)的事件綁定  
  17.             }  
  18.             else{  
  19.                 this.attachEvent("on"+event,fun);//IE的事件綁定  
  20.             }  
  21.         }  
  22.  
  23.         DOMExtend("bind",BindEvent);//執(zhí)行功能擴(kuò)展  
  24.  
  25.         var tagA=document.getElementById("tagA");  
  26.           
  27.         tagA.bind("click",function(){//這就是我們最終要實現(xiàn)的功能  
  28.             alert(this.innerHTML);  
  29.         })  
  30.  
  31.     //--> 
  32.     </script> 
  33.  </body> 
  34. </html> 

執(zhí)行以上這個頁面,在IE9,Chrome,Opera,Firefox等標(biāo)準(zhǔn)瀏覽器里都能正常觸發(fā)tagA的點擊事件,于是現(xiàn)在只剩下一個問題,就是要兼容其他瀏覽器;IE瀏覽器之所以出錯,是因為它們隱藏了對HTMLElement的訪問,于是針對IE瀏覽器,我們就不能用HTMLElement.prototype來進(jìn)行擴(kuò)展了,但我們可以通過重寫以下幾個函數(shù)來達(dá)到目的:

document.getElementById

document.getElementsByTagName

document.createElement

document.documentElement

document.body

(PS:記憶中獲取DOM元素好像就是以上這些方法了~不知道還有沒有其他)

重寫后,再進(jìn)行一些處理變換就可以得到以下完整的頁面代碼:

  1. <!DOCTYPE html> 
  2. <html lang="zh"> 
  3.  <head> 
  4.   <title>DOM功能擴(kuò)展</title> 
  5.  </head> 
  6.  
  7.  <body> 
  8.     <a href="javascript:void(0)" id="tagA">你好</a> 
  9.     <script type="text/javascript"> 
  10.         function DOMExtend(name, fn){  
  11.             if(typeof(HTMLElement)!="undefined"){  
  12.                 eval("HTMLElement.prototype."+name+"="+fn);  
  13.             }  
  14.             else{  
  15.                 var _getElementById=document.getElementById;  
  16.                 document.getElementById=function(id){  
  17.                     var _elem=_getElementById(id);  
  18.                     eval("_elem."+name+"="+fn);  
  19.                     return _elem;  
  20.                 }  
  21.  
  22.                 var _getElementByTagName=document.getElementsByTagName;  
  23.                 document.getElementsByTagName=function(tag){  
  24.                     var _elem=_getElementByTagName(tag);  
  25.                     var len=_elem.length;  
  26.                     for(var i=0;i<len;i++){  
  27.                         eval("_elem["+i+"]."+name+"="+fn);  
  28.                     }  
  29.                     return _elem;  
  30.                 }  
  31.  
  32.                 var _createElement=document.createElement;  
  33.                 document.createElement=function(tag){  
  34.                     var _elem=_createElement(tag);  
  35.                     eval("_elem."+name+"="+fn);  
  36.                     return _elem;  
  37.                 }  
  38.  
  39.                 var _documentElement=document.documentElement;  
  40.                 eval("_documentElement."+name+"="+fn);  
  41.  
  42.                 var _documentBody=document.body;  
  43.                 eval("_documentBody."+name+"="+fn);  
  44.             }  
  45.         }  
  46.  
  47.         function BindEvent(event,fun){  
  48.             if(this.addEventListener){  
  49.                 this.addEventListener(event,fun,false);  
  50.             }  
  51.             else{  
  52.                 this.attachEvent("on"+event,fun);  
  53.             }  
  54.         }  
  55.  
  56.         DOMExtend("bind",BindEvent);var wrap=document.getElementById("tagA");  
  57.  
  58.         wrap.bind("click",function(){  
  59.             alert(this.innerHTML);  
  60.         })  
  61.     </script> 
  62.  </body> 
  63. </html> 

OK,目前為止已經(jīng)解決了兼容性問題,這是所有瀏覽器都能順利通過的DOM元素擴(kuò)展的代碼,但是這樣還有一個小問題,細(xì)心的人會發(fā)現(xiàn)在IE瀏覽器里面彈出的結(jié)果是"undefined",而不是"你好";問題的原因在于IE的事件綁定上,看以上代碼,當(dāng)調(diào)用alert(this.innerHTML)的時候,由于IE綁定事件用的是attachEvent,這時候this指向的是windows,于是現(xiàn)在的目標(biāo)的要改變this指向的對像,將this指向tagA。于是經(jīng)過修改,完整代碼如下:

  1. <!DOCTYPE html> 
  2. <html lang="zh"> 
  3.  <head> 
  4.   <title>DOM功能擴(kuò)展</title> 
  5.  </head> 
  6.  
  7.  <body> 
  8.     <a href="javascript:void(0)" id="tagA">你好</a> 
  9.     <script type="text/javascript"> 
  10.         function DOMExtend(name, fn){  
  11.             if(typeof(HTMLElement)!="undefined"){  
  12.                 eval("HTMLElement.prototype."+name+"="+fn);  
  13.             }  
  14.             else{  
  15.                 var _getElementById=document.getElementById;  
  16.                 document.getElementById=function(id){  
  17.                     var _elem=_getElementById(id);  
  18.                     eval("_elem."+name+"="+fn);  
  19.                     return _elem;  
  20.                 }  
  21.  
  22.                 var _getElementByTagName=document.getElementsByTagName;  
  23.                 document.getElementsByTagName=function(tag){  
  24.                     var _elem=_getElementByTagName(tag);  
  25.                     var len=_elem.length;  
  26.                     for(var i=0;i<len;i++){  
  27.                         eval("_elem["+i+"]."+name+"="+fn);  
  28.                     }  
  29.                     return _elem;  
  30.                 }  
  31.  
  32.                 var _createElement=document.createElement;  
  33.                 document.createElement=function(tag){  
  34.                     var _elem=_createElement(tag);  
  35.                     eval("_elem."+name+"="+fn);  
  36.                     return _elem;  
  37.                 }  
  38.  
  39.                 var _documentElement=document.documentElement;  
  40.                 eval("_documentElement."+name+"="+fn);  
  41.  
  42.                 var _documentBody=document.body;  
  43.                 eval("_documentBody."+name+"="+fn);  
  44.             }  
  45.         }  
  46.  
  47.         function BindEvent(event,fun){  
  48.             if(this.addEventListener){  
  49.                 this.addEventListener(event,fun,false);  
  50.             }  
  51.             else{  
  52.                 var tag=this;  
  53.                 tag.attachEvent("on"+event,function(){  
  54.                     fun.apply(tag,arguments);//這里是關(guān)鍵  
  55.                 });  
  56.             }  
  57.         }  
  58.  
  59.         DOMExtend("bind",BindEvent);var wrap=document.getElementById("tagA");  
  60.  
  61.         wrap.bind("click",function(){  
  62.             alert(this.innerHTML);  
  63.         })  
  64.     </script> 
  65.  </body> 
  66. </html> 

原文鏈接:http://www.cnblogs.com/xueming/archive/2012/07/30/2615077.html

責(zé)任編輯:林師授 來源: 博客園
相關(guān)推薦

2009-08-18 13:59:21

C#多標(biāo)簽瀏覽器

2013-03-19 14:16:51

Chrome瀏覽器

2021-05-17 14:15:16

Edge瀏覽器Android翻譯功能

2015-01-21 15:45:50

斯巴達(dá)瀏覽器

2011-06-28 14:26:05

Opera瀏覽器

2010-09-15 09:12:03

JavaScript瀏覽器兼容

2013-11-22 09:58:36

2012-09-07 13:57:24

瀏覽器Chrome

2021-08-28 06:15:49

瀏覽器手機(jī)瀏覽器夸克

2022-05-30 07:58:52

瀏覽器插件

2011-09-15 16:33:25

2021-09-27 14:39:12

HTTPS Everw瀏覽器擴(kuò)展Google

2021-06-05 07:51:11

ChromeSafariFirefox

2010-03-25 11:15:56

Google Chro

2010-09-15 09:43:24

Javascript瀏覽器兼容

2010-09-16 11:21:54

FirefoxJS

2010-08-11 13:35:10

JavaScriptCSS

2022-04-07 09:00:00

跨瀏覽器測試自動化服務(wù)異常

2011-04-12 16:51:29

Javascript兼容性

2010-04-05 21:57:14

Netscape瀏覽器
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 91新视频| 9191在线播放 | 日本不卡一区二区 | 亚洲免费在线观看 | 日韩视频在线免费观看 | 久久久国产精品视频 | 97精品国产 | 在线激情视频 | 欧美在线资源 | 久久伊人操 | 成人精品毛片国产亚洲av十九禁 | 欧美日韩国产一区二区三区不卡 | 天堂中文资源在线 | 欧美亚洲国语精品一区二区 | 亚洲精品亚洲人成人网 | 中文字幕av在线播放 | 91社区在线观看 | 在线成人精品视频 | 欧美在线看片 | 国产精品久久久久久久久久久久冷 | 国产精品69久久久久水密桃 | 国产www在线 | av免费看片 | 国产亚洲欧美另类一区二区三区 | 色综合av| 国产成人一区二 | 一a级片 | 青青草av网站 | 老司机久久 | 久久亚洲一区二区 | 久久精品免费观看 | 欧美激情久久久 | 亚洲欧美另类在线观看 | 日韩中文字幕免费在线观看 | 久久精品91 | 黄网站涩免费蜜桃网站 | h免费观看 | 国产欧美日韩综合精品一区二区 | 日韩欧美国产精品一区 | 涩爱av一区二区三区 | 三级黄色大片网站 |