精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

淺析JavaScript的事件代理和委托

開發 前端
在javasript中delegate這個詞經常出現,看字面的意思,代理、委托。那么它究竟在什么樣的情況下使用?它的原理又是什么?在各種框架中,也經常能看到delegate相關的接口。這些接口又有什么特殊的用法呢?這篇文章就主要介紹一下javascript delegate的用法和原理,以及Dojo,jQuery等框架中delegate的接口。

在javasript中delegate這個詞經常出現,看字面的意思,代理、委托。那么它究竟在什么樣的情況下使用?它的原理又是什么?在各種框架中,也經常能看到delegate相關的接口。這些接口又有什么特殊的用法呢?這篇文章就主要介紹一下javascript delegate的用法和原理,以及Dojo,jQuery等框架中delegate的接口。

JavaScript事件代理

首先介紹一下JavaScript的事件代理。事件代理在JS世界中一個非常有用也很有趣的功能。當我們需要對很多元素添加事件的時候,可以通過將事件添加到它們的父節點而將事件委托給父節點來觸發處理函數。這主要得益于瀏覽器的事件冒泡機制,后面會詳細介紹。下面我們具體舉個例子來解釋如何使用這個特性。這個例子主要取自David Walsh的相關文章(How JavaScript Event Delegation Works)。

假設有一個 UL 的父節點,包含了很多個 Li 的子節點:

  1. <ul id="parent-list"
  2.   <li id="post-1">Item 1</li> 
  3.   <li id="post-2">Item 2</li> 
  4.   <li id="post-3">Item 3</li> 
  5.   <li id="post-4">Item 4</li> 
  6.   <li id="post-5">Item 5</li> 
  7.   <li id="post-6">Item 6</li> 
  8. </ul>  

當我們的鼠標移到Li上的時候,需要獲取此Li的相關信息并飄出懸浮窗以顯示詳細信息,或者當某個Li被點擊的時候需要觸發相應的處理事件。我們通常的寫法,是為每個Li都添加一些類似onMouseOver或者onClick之類的事件監聽。

  1. function addListeners4Li(liNode){ 
  2.     liNode.onclick = function clickHandler(){...}; 
  3.     liNode.onmouseover = function mouseOverHandler(){...} 
  4.  
  5. window.onload = function(){ 
  6.     var ulNode = document.getElementById("parent-list"); 
  7.     var liNodes = ulNode.getElementByTagName("Li"); 
  8.     for(var i=0, l = liNodes.length; i < l; i++){ 
  9.         addListeners4Li(liNodes[i]); 
  10.     }    
  11.  

如果這個UL中的Li子元素會頻繁地添加或者刪除,我們就需要在每次添加Li的時候都調用這個addListeners4Li方法來為每個Li節點添加事件處理函數。這就添加的復雜度和出錯的可能性。

更簡單的方法是使用事件代理機制,當事件被拋到更上層的父節點的時候,我們通過檢查事件的目標對象(target)來判斷并獲取事件源Li。下面的代碼可以完成我們想要的效果:

  1. // 獲取父節點,并為它添加一個click事件 
  2. document.getElementById("parent-list").addEventListener("click",function(e) { 
  3.   // 檢查事件源e.targe是否為Li 
  4.   if(e.target && e.target.nodeName.toUpperCase == "LI") { 
  5.     // 真正的處理過程在這里 
  6.     console.log("List item ",e.target.id.replace("post-")," was clicked!"); 
  7.   } 
  8. });  

為父節點添加一個click事件,當子節點被點擊的時候,click事件會從子節點開始向上冒泡。父節點捕獲到事件之后,通過判斷e.target.nodeName來判斷是否為我們需要處理的節點。并且通過e.target拿到了被點擊的Li節點。從而可以獲取到相應的信息,并作處理。

事件冒泡及捕獲

之前的介紹中已經說到了瀏覽器的事件冒泡機制。這里再詳細介紹一下瀏覽器處理DOM事件的過程。對于事件的捕獲和處理,不同的瀏覽器廠商有不同的處理機制,這里我們主要介紹W3C對DOM2.0定義的標準事件。

DOM2.0模型將事件處理流程分為三個階段:一、事件捕獲階段,二、事件目標階段,三、事件起泡階段。如圖:

 事件捕獲:當某個元素觸發某個事件(如onclick),頂層對象document就會發出一個事件流,隨著DOM樹的節點向目標元素節點流去,直到到達事件真正發生的目標元素。在這個過程中,事件相應的監聽函數是不會被觸發的。

事件目標:當到達目標元素之后,執行目標元素該事件相應的處理函數。如果沒有綁定監聽函數,那就不執行。

事件起泡:從目標元素開始,往頂層元素傳播。途中如果有節點綁定了相應的事件處理函數,這些函數都會被一次觸發。如果想阻止事件起泡,可以使用e.stopPropagation()(Firefox)或者e.cancelBubble=true(IE)來組織事件的冒泡傳播。

jQuery和Dojo中delegate函數

下面看一下Dojo和jQuery中提供的事件代理接口的使用方法。

  1. $("#link-list").delegate("a""click"function(){ 
  2.   // "$(this)" is the node that was clicked 
  3.   console.log("you clicked a link!",$(this)); 
  4. });  

jQuery的delegate的方法需要三個參數,一個選擇器,一個時間名稱,和事件處理函數。

而Dojo的與jQuery相似,僅是兩者的編程風格上的差別:

  1. require(["dojo/query","dojox/NodeList/delegate"], function(query,delegate){ 
  2.  
  3.     query("#link-list").delegate("a","onclick",function(event) { 
  4.     // "this.node" is the node that was clicked 
  5.     console.log("you clicked a link!",this); 
  6.   }); 
  7. })  

Dojo的delegate模塊在dojox.NodeList中,提供的接口與jQuery一樣,參數也相同。

優點通過上面的介紹,大家應該能夠體會到使用事件委托對于web應用程序帶來的幾個優點:

1.管理的函數變少了。不需要為每個元素都添加監聽函數。對于同一個父節點下面類似的子元素,可以通過委托給父元素的監聽函數來處理事件。

2.可以方便地動態添加和修改元素,不需要因為元素的改動而修改事件綁定。

3.JavaScript和DOM節點之間的關聯變少了,這樣也就減少了因循環引用而帶來的內存泄漏發生的概率。

寫到這里,突然想起了之前對于Dojo DataGrid的困惑:那么多的rows和cells,如何處理他們事件之間的關系。現在想想,使用委托就很簡單了。所有的事件委托到grid最外層的節點上,當事件發生的時候通過一些方法來獲取和添加事件的額外屬性,如rowIndex, cellIndex,之后在分配到onRowClick,onCellClick之類的處理函數上。

在JavaScript編程中使用代理

上面介紹的是對DOM事件處理時,利用瀏覽器冒泡機制為DOM元素添加事件代理。其實在純JS編程中,我們也可以使用這樣的編程模式,來創建代理對象來操作目標對象。這里引用司徒正美相關文章中的一個例子:

  1. var delegate = function(client, clientMethod) { 
  2.         return function() { 
  3.             return clientMethod.apply(client, arguments); 
  4.         } 
  5.     } 
  6.     var ClassA = function() { 
  7.         var _color = "red"
  8.         return { 
  9.             getColor: function() { 
  10.                 console.log("Color: " + _color); 
  11.             }, 
  12.             setColor: function(color) { 
  13.                 _color = color; 
  14.             } 
  15.         }; 
  16.     }; 
  17.  
  18.     var a = new ClassA(); 
  19.     a.getColor(); 
  20.     a.setColor("green"); 
  21.     a.getColor(); 
  22.     console.log("執行代理!"); 
  23.     var d = delegate(a, a.setColor); 
  24.     d("blue"); 
  25.     console.log("執行完畢!"); 
  26.     a.getColor();  

上面的例子中,通過調用delegate()函數創建的代理函數d來操作對a的修改。這種方式盡管是使用了apply(call也可以)來實現了調用對象的轉移,但是從編程模式上實現了對某些對象的隱藏,可以保護這些對象不被隨便訪問和修改。

在很多框架中都引用了委托這個概念用來指定方法的運行作用域。比較典型的如dojo.hitch(scope,method)和ExtJS的createDelegate(obj,args)。有興趣的同學可以看一下他們的源代碼,主要也是js函數的apply方法來制定執行作用域。

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2009-10-09 09:07:40

C#委托和事件

2021-07-27 22:56:00

JavaScript編程開發

2011-06-16 14:38:18

JavaScript事件委托

2009-01-19 09:40:53

JavaScript事件代理事件處理器

2021-10-19 09:31:19

Javascript 登錄表單前端

2021-03-16 10:00:40

JavaScript用戶登錄表單JavaScript基

2024-12-26 16:13:53

JavaScript開發表單

2011-06-16 15:14:17

VB.NET事件委托

2009-08-18 10:54:17

C#事件和委托

2009-08-20 18:37:52

委托C#異步委托

2024-06-28 10:19:02

委托事件C#

2009-08-31 18:34:57

C#接口事件

2009-08-27 16:53:01

C#委托C#事件

2009-08-26 14:27:54

C#委托和事件

2009-08-31 09:20:37

C#事件注冊和注銷

2009-08-18 11:08:24

.Net Framew

2024-05-16 13:36:04

C#委托事件

2022-07-28 08:34:59

事件委托JS

2013-03-19 09:48:38

C#

2024-02-04 17:16:22

ReactVue前端
點贊
收藏

51CTO技術棧公眾號

日韩国产在线观看| 亚洲区小说区图片区qvod| 亚洲精品欧美二区三区中文字幕| 91精品美女在线| 久久这里只有精品国产| 亚洲激情77| 9191久久久久久久久久久| 国产真人做爰毛片视频直播| 国产中文字幕在线看| 韩国精品久久久| 91精品国产91久久久| 日韩av片在线免费观看| 精品少妇3p| 欧美肥妇毛茸茸| 国产在线青青草| a级在线观看| 久久精品亚洲麻豆av一区二区| 91嫩草视频在线观看| 天天爱天天做天天爽| 伊人久久综合| 不卡av电影在线观看| 亚欧洲乱码视频| 亚洲日本一区二区三区在线| 在线免费观看成人短视频| 成年女人18级毛片毛片免费| 欧洲不卡av| 久久久久久久久久看片| 国产精品福利视频| 97超视频在线观看| 日韩成人午夜电影| 国产91成人video| 青娱乐91视频| 国产a久久精品一区二区三区| 欧美电视剧在线看免费| av噜噜在线观看| 国产一区二区三区影视| 日韩欧美高清视频| 久久久久久久久久久99| 精精国产xxxx视频在线中文版| 亚洲欧洲日韩女同| 亚洲国产欧美不卡在线观看| 看电影就来5566av视频在线播放| av一二三不卡影片| 国产伦精品一区二区三区照片91 | 91九色蝌蚪嫩草| 亚洲一线在线观看| 日本不卡不码高清免费观看| 国产成人精品午夜| 国产黄色免费观看| 国产欧美日本| 97**国产露脸精品国产| 男人的天堂一区二区| 在线欧美不卡| 国语自产精品视频在线看一大j8 | 成人免费午夜电影| 在线观看中文字幕2021| 美国av一区二区| 国产免费一区视频观看免费| 亚洲永久精品视频| 国内成+人亚洲+欧美+综合在线| 国产日韩欧美自拍| 国产乱淫片视频| 国产乱码精品一区二区三区av| 91免费看片在线| 亚洲成人一二三区| www.性欧美| 欧美另类一区| 亚洲搞黄视频| 亚洲日本在线a| 天堂8在线天堂资源bt| 草美女在线观看| 欧美日韩一区二区在线播放| 欧美日韩在线成人| 无码人妻精品一区二区三区不卡| 欧美一级久久| 国产成人久久久| 亚洲性生活大片| 国产乱人伦精品一区二区在线观看| 114国产精品久久免费观看| 亚洲精品一区二区口爆| 久久只精品国产| 亚洲福利av在线| 中文字幕在线观看网站| 精品久久久久久中文字幕| caopor在线视频| 国产成人免费av一区二区午夜| 欧美不卡视频一区| 这里只有久久精品| 久久久久久久久久久久久久久久久久| 欧美精品福利在线| 日韩美一区二区| 国内精品视频一区二区三区八戒| 波多野结衣成人在线| 欧美zzoo| 曰韩精品一区二区| 成人在线看视频| 久久9999免费视频| 亚洲精品一区二区网址| 动漫性做爰视频| 美女诱惑一区| 99精彩视频在线观看免费| 国内三级在线观看| 亚洲一级在线观看| 久久撸在线视频| 蜜臀av一区| 久久精品一本久久99精品| 三级黄色在线视频| 狠狠色狠狠色综合| 日本一区美女| 草草视频在线| 欧美一区二区三区精品| 乐播av一区二区三区| 国内精品嫩模av私拍在线观看| 日韩av电影在线播放| 高清乱码毛片入口| 亚洲欧洲99久久| 久久久精品在线视频| 亚洲专区**| 久久久国产一区| 亚洲中文一区二区| 99久久精品国产一区二区三区| 只有这里有精品| 久久精品国产福利| 亚洲香蕉av在线一区二区三区| 国产一级在线视频| 国产尤物一区二区| 一区二区三区四区国产| 国产精品极品美女在线观看| 亚洲成人精品av| 欧美精品99久久久| 精品一区二区三区久久久| 日韩精品不卡| 午夜精品成人av| 日韩精品在线观看一区二区| 久久视频免费在线观看| 伊人影院久久| 91久久久一线二线三线品牌| 国产成人l区| 91精品免费在线| 国精品人伦一区二区三区蜜桃| 日韩av不卡在线观看| 欧美色图亚洲自拍| www.日韩| 亚洲美女精品久久| 久久精品视频5| 久久综合九色综合97婷婷女人| 黄页网站大全在线观看| 国产精品超碰| 性亚洲最疯狂xxxx高清| 午夜视频免费在线| 精品欧美国产一区二区三区| 亚洲天堂av网站| 在线播放亚洲| 国产原创精品| 亚洲天堂资源| 亚洲天堂成人在线| 337p粉嫩色噜噜噜大肥臀| 日本一区二区三区四区在线视频| 91淫黄看大片| 日韩欧美二区| 91精品在线一区| 日韩电影免费观看| 亚洲高清在线观看| 国产在线观看黄色| 欧美国产激情二区三区| 亚洲另类第一页| 午夜精品久久久久99热蜜桃导演| 波多野结衣久草一区| 欧美久久天堂| 揄拍成人国产精品视频| 国产免费不卡视频| 亚洲一区二区av电影| 中文字幕5566| 久久电影网电视剧免费观看| 欧洲美女和动交zoz0z| 88久久精品| 日韩美女中文字幕| 免费大片在线观看www| 欧美成人精品高清在线播放| 可以免费看的av毛片| 国产人成亚洲第一网站在线播放| 日韩成人精品视频在线观看| 欧美午夜国产| 日本在线播放一区| 欧美高清一级片| 欧美野外猛男的大粗鳮| av资源在线观看免费高清| 91精品国产美女浴室洗澡无遮挡| 久久久久久久99| 中日韩av电影| 妖精视频一区二区| 蜜臀a∨国产成人精品| 美女av免费观看| 沈樵精品国产成av片| 亚洲一区二区三区视频| 涩涩视频在线播放| 久久精品国产成人| 日本福利在线观看| 日韩三级中文字幕| 91视频久久久| 午夜欧美一区二区三区在线播放| 免费一级做a爰片久久毛片潮| 国产精品一区一区| 亚洲成人av免费看| 亚洲每日在线| 婷婷视频在线播放| 国产成人精品三级高清久久91| 亚洲综合精品一区二区| 日韩欧美一区二区三区免费观看 | 日韩视频一区二区在线观看| 亚洲第一网站在线观看| 亚洲综合另类小说| 国产精品www爽爽爽| 99精品视频在线免费观看| av噜噜在线观看| 人人爽香蕉精品| 久久亚洲中文字幕无码| 一区二区三区中文| 神马影院我不卡| 欧美黑人做爰爽爽爽| 51国偷自产一区二区三区| 日本在线精品| 欧美又大又粗又长| 97人人爽人人澡人人精品| 久久国产精品99国产精| 五月婷婷在线观看| 亚洲视频一区二区三区| 亚洲色图另类小说| 精品99999| 国产av无码专区亚洲av麻豆| 欧美日韩国产电影| 中文字幕高清在线免费播放| 黄色成人av在线| 久久精品国产亚洲av香蕉| 亚洲精品综合在线| 欧美性x x x| 国产精品国产三级国产普通话三级| 成人免费无遮挡无码黄漫视频| 99re免费视频精品全部| 亚洲精品国产成人av在线| 国产成人精品免费一区二区| 波多野结衣免费观看| 国产乱码精品一区二区三区五月婷| 久久久精品高清| 韩国av一区二区三区在线观看| 天天色综合社区| 美女视频黄免费的久久| 日本激情视频在线播放| 蜜臀久久99精品久久久画质超高清| www黄色av| 蜜桃久久av| 手机看片福利日韩| 奇米影视7777精品一区二区| 91极品视频在线观看| 麻豆久久一区二区| 一区二区三区欧美精品| 国产美女久久久久| 免费在线观看日韩av| 成人午夜在线免费| 99久久人妻无码中文字幕系列| proumb性欧美在线观看| 国产男女猛烈无遮挡a片漫画| 久久日韩精品一区二区五区| 欧洲美一区二区三区亚洲| 亚洲国产精品精华液ab| 久久国产高清视频| 亚洲精品国产高清久久伦理二区| 国产一级久久久| 狠狠躁夜夜躁久久躁别揉| 亚洲欧美一区二区三区在线观看| 欧美伊人久久久久久久久影院| 在线观看国产一区二区三区| 欧美一级国产精品| 色婷婷av一区二区三区之红樱桃| 精品国产91久久久久久| 国产女主播喷水视频在线观看 | 欧美在线观看视频网站| 久久www免费人成看片高清| 韩国三级hd中文字幕有哪些| 97se狠狠狠综合亚洲狠狠| 一区二区黄色片| 中文字幕佐山爱一区二区免费| 久草视频手机在线观看| 日韩欧美中文第一页| 亚洲无码久久久久久久| 亚洲国产成人爱av在线播放| 韩国免费在线视频| 欧美肥老妇视频| 美女100%一区| 99久久精品免费看国产四区 | 亚洲免费视频一区| 欧美日韩在线大尺度| 日韩手机在线观看视频| 国产美女久久久久| 中文字幕人妻一区二区三区在线视频| 亚洲素人一区二区| 超碰超碰超碰超碰| 欧美一卡二卡三卡| 国产污视频在线| 欧美精品性视频| 另类中文字幕国产精品| 国产精品视频在线免费观看| 精品国产91乱码一区二区三区四区 | 国产成人精品视频在线观看| 一区二区三区高清在线观看| 日韩欧美第二区在线观看| 亚洲东热激情| 99热一区二区| 国产午夜精品福利| 国产一级做a爱免费视频| 欧美伦理视频网站| 欧美孕妇孕交| 久久久久久尹人网香蕉| 日本免费成人| 欧美一区二区影视| 亚洲日本国产| 被黑人猛躁10次高潮视频| 亚洲国产精品成人久久综合一区 | 亚洲国产高清一区| 久久精品国产99久久99久久久| 久久精品这里都是精品| 黄色小说在线观看视频| 日韩一区二区在线看| 亚洲乱亚洲乱妇| 国产精品旅馆在线| 亚洲婷婷影院| 国产免费黄视频| 成人黄色一级视频| 国产精品111| 日韩一级成人av| 黄色国产网站在线播放| 国产精品美女无圣光视频| 免费av一区| 亚洲欧洲日产国码无码久久99| 成人国产在线观看| 九九视频免费在线观看| 日韩欧美一二区| a黄色片在线观看| 亚洲xxxx18| 欧美喷水视频| 中文写幕一区二区三区免费观成熟| 成人免费在线视频观看| 国产精品久久久久久久一区二区 | 毛片大全在线观看| 91精品天堂| 黑丝一区二区三区| 日本精品一二三| 亚洲午夜精品网| 六月婷婷综合网| 91精品国产高清自在线| 久久影视三级福利片| 日韩av高清在线看片| 99r国产精品| 天天干天天干天天| 亚洲香蕉伊综合在人在线视看| 美女100%一区| 亚洲日本精品| 精品一区中文字幕| 久久久久久久久久网站| 精品盗摄一区二区三区| 极品视频在线| 日本一区二区久久精品| 久久爱www久久做| 四虎精品免费视频| 精品国产乱码久久久久久1区2区| 9999精品成人免费毛片在线看| 久久99精品久久久久久青青日本 | 亚洲一区成人在线| 日韩美女一级视频| 国产精品男人的天堂| 911久久香蕉国产线看观看| 中国特级黄色片| 日韩欧美999| 国产写真视频在线观看| 国产精品免费一区二区三区观看 | 水莓100国产免费av在线播放| 日本精品视频网站| 日韩国产一区| 亚洲熟女一区二区三区| 精品毛片网大全| 91精品国产综合久久久久久豆腐| 91大片在线观看| 六月婷婷一区| 日韩一级片大全| 日韩电影中文字幕在线| 成人在线免费av| 精品国产一区二区三区无码| 久久精品一区八戒影视| 国产丝袜视频在线观看| 欧美专区日韩视频| 亚洲va在线| 毛茸茸多毛bbb毛多视频| 51久久夜色精品国产麻豆| 国模精品视频| 中文字幕一区二区中文字幕| av一区二区三区在线| 国产乱淫a∨片免费视频| 日韩美女激情视频| 欧美午夜国产| 秋霞网一区二区三区|