中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

JavaScript事件代理和委托詳解
來源:易賢網 閱讀:1007 次 日期:2016-07-08 14:14:08
溫馨提示:易賢網小編為您整理了“JavaScript事件代理和委托詳解”,方便廣大網友查閱!

這篇文章主要為大家詳細介紹了JavaScript事件代理和委托,感興趣的小伙伴們可以參考一下

在javasript中,代理、委托經常出現。

那么它究竟在什么樣的情況下使用?它的原理又是什么?

這里介紹一下javascript delegate的用法和原理,以及Dojo,jQuery等框架中delegate的接口。

JavaScript事件代理

事件代理在JS世界中一個非常有用也很有趣的功能。當我們需要對很多元素添加事件的時候,可以通過將事件添加到它們的父節點而將事件委托給父節點來觸發處理函數。

這主要得益于瀏覽器的事件冒泡機制,下面我們具體舉個例子來解釋如何使用這個特性。

這個例子主要取自David Walsh的相關文章(How JavaScript Event Delegation Works)。

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

<ul id="list">

 <li id="li-1">Li 1</li>

 <li id="li-2">Li 2</li>

 <li id="li-3">Li 3</li>

 <li id="li-4">Li 4</li>

 <li id="li-5">Li 5</li> 

</ul>

當我們的鼠標移到Li上的時候,需要獲取此Li的相關信息并飄出懸浮窗以顯示詳細信息,或者當某個Li被點擊的時候需要觸發相應的處理事件。

我們通常的寫法,是為每個Li都添加一些類似onMouseOver或者onClick之類的事件監聽。

function addListenersLi(liElement) {

  liElement.onclick = function clickHandler() {

   //TODO

  };

  liElement.onmouseover = function mouseOverHandler() {

   //TODO

  }

 }

 window.onload = function() {

  var ulElement = document.getElementById("list");

  var liElements = ulElement.getElementByTagName("Li");

   for (var i = liElements.length - 1; i >= 0; i--) {

    addListenersLi(liElements[i]);

   } 

 }

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

這會造成添加或者刪除過程的復雜度和出錯的可能性。

解決問題方法是使用事件代理機制,當事件被拋到更上層的父節點的時候,我們通過檢查事件的目標對象(target)來判斷并獲取事件源Li。

下面的代碼可以完成想要的效果: 

/ 獲取父節點,并為它添加一個click事件

document.getElementById("list").addEventListener("click",function(e) {

 // 檢查事件源e.targe是否為Li

 if(e.target && e.target.nodeName.toUpperCase == "LI") {

 // 

 //TODO

 console.log("List item ",e.target.id," was clicked!");

 }

});

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

事件冒泡及捕獲

瀏覽器的事件冒泡機制,對于事件的捕獲和處理,不同的瀏覽器廠商有不同的處理機制,這里介紹W3C對DOM2.0定義的標準事件。

DOM2.0模型將事件處理流程分為三個階段:

一、事件捕獲階段,

二、事件目標階段,

三、事件起泡階段。

如下圖:

名單

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

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

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

jQuery和Dojo中delegate函數

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

jQuery:

$("#list").delegate("li", "click", function(){

 // "$(this)" is the node that was clicked

 console.log("you clicked a link!",$(this));

});

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

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

require(["dojo/query","dojox/NodeList/delegate"], function(query,delegate){

 query("#list").delegate("li","onclick",function(event) {

 // "this.node" is the node that was clicked

 console.log("you clicked a link!",this);

 });

})

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

通過委托, 能夠體會到使用事件委托對于開發帶來的幾個好處:

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

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

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

在JavaScript編程中使用代理

上面介紹的是對DOM事件處理時,利用瀏覽器冒泡機制為DOM元素添加事件代理。其實在純JS編程中,我們也可以使用這樣的編程模式,來創建代理對象來操作目標對象.

var delegate = function(client, clientMethod) {

  return function() {

   return clientMethod.apply(client, arguments);

  }

 }

 var Apple= function() {

  var _color = "red";

  return {

   getColor: function() {

    console.log("Color: " + _color);

   },

   setColor: function(color) {

    _color = color;

   }

  };

 };

 var a = new Apple();

 var b = new Apple();

 a.getColor();

 a.setColor("green");

 a.getColor();

 //調用代理

 var d = delegate(a, a.setColor);

 d("blue");

 //執行代理

 a.getColor();

 //b.getColor();

上面的例子中,通過調用delegate()函數創建的代理函數d來操作對a的修改。

這種方式盡管是使用了apply(call也可以)來實現了調用對象的轉移,但是從編程模式上實現了對某些對象的隱藏,可以保護這些對象不被隨便訪問和修改。

在很多框架中都引用了委托這個概念用來指定方法的運行作用域。

比較典型的如dojo.hitch(scope,method)和ExtJS的createDelegate(obj,args)。

以上就是本文的全部內容,希望對大家學習javascript程序設計有所幫助。

更多信息請查看網絡編程
易賢網手機網站地址:JavaScript事件代理和委托詳解
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
亚洲欧美美女| 国产精品普通话对白| 久久久综合激的五月天| 在线观看视频欧美| 久久久爽爽爽美女图片| 久久国产精品亚洲77777| 欧美一区二区性| 欧美日韩成人一区二区三区| 欧美aa国产视频| 久久久亚洲国产天美传媒修理工| 久久久精品欧美丰满| 国产精品一区二区在线观看网站 | 欧美老女人xx| 最新国产の精品合集bt伙计| 男女精品网站| 99re这里只有精品6| 欧美吻胸吃奶大尺度电影| 久久国产精品久久久| 亚洲国产精品一区二区www| 亚洲一区二区三区777| 久久夜色精品国产欧美乱极品| 久久精品视频免费| 欧美日韩国产三区| 欧美一区二区三区的| 国产农村妇女毛片精品久久麻豆 | 欧美日韩一区二区在线视频| 亚洲精品五月天| 欧美视频专区一二在线观看| 亚洲欧美日韩国产中文| 国产日韩精品在线播放| 免费观看成人网| 亚洲手机在线| 国产一区成人| 国产精品日韩在线播放| 欧美日韩免费一区| 蜜臀av一级做a爰片久久| 日韩午夜免费| 国内不卡一区二区三区| 在线中文字幕一区| 亚洲人线精品午夜| 欧美国产日韩在线| 亚洲一区二区成人| 伊大人香蕉综合8在线视| 久久综合一区二区| 一本色道精品久久一区二区三区| 国产精自产拍久久久久久| 欧美aa在线视频| 午夜精品久久久久久久男人的天堂 | 黄色成人片子| 欧美精品久久久久久久| 欧美中文字幕在线观看| 亚洲黄网站在线观看| 国产欧美日本| 国产精品www| 欧美日韩久久精品| 欧美成人午夜影院| 久久xxxx| 日韩视频免费观看高清在线视频| 国产日韩精品在线播放| 欧美午夜电影在线观看| 你懂的亚洲视频| 久久久国产一区二区| 欧美一二三区在线观看| 午夜老司机精品| 欧美在线|欧美| 久久精品二区| 母乳一区在线观看| 欧美大片一区二区三区| 欧美福利影院| 欧美日韩国产首页在线观看| 欧美精选午夜久久久乱码6080| 欧美国内亚洲| 国产精品久久久久三级| 国产日韩欧美一区在线 | 久久黄色级2电影| 欧美在线亚洲一区| 女生裸体视频一区二区三区| 欧美日韩精品免费观看视频| 国产精品九九| 在线观看中文字幕亚洲| 一本色道久久综合亚洲精品按摩| 亚洲综合欧美| 久久永久免费| 国产精品草莓在线免费观看| 国产午夜久久久久| 亚洲精品永久免费| 欧美一区二区三区在线播放| 欧美大香线蕉线伊人久久国产精品| 欧美色大人视频| 国语自产精品视频在线看8查询8| 亚洲国产精品成人久久综合一区| 一区二区三区久久| 久久性色av| 国产精品久久久久aaaa樱花| 国内精品久久久| 日韩一级网站| 乱人伦精品视频在线观看| 国产精品高精视频免费| 亚洲韩国青草视频| 亚洲欧美影音先锋| 欧美另类变人与禽xxxxx| 国产亚洲一本大道中文在线| 日韩一区二区精品| 久久综合久久88| 国产精品永久入口久久久| 亚洲激情六月丁香| 久久久99国产精品免费| 国产精品久久久| 亚洲精品社区| 久久一区精品| 国产主播一区| 久久精彩视频| 国产欧美精品在线播放| 一本色道久久综合狠狠躁的推荐| 每日更新成人在线视频| 国内综合精品午夜久久资源| 性色av香蕉一区二区| 国产精品嫩草99a| 一本色道久久综合狠狠躁篇怎么玩 | 99国内精品久久| 理论片一区二区在线| 国产真实乱偷精品视频免| 香蕉av777xxx色综合一区| 国产精品毛片在线| 亚洲砖区区免费| 国产精品入口66mio| 一区二区三区欧美在线观看| 蜜乳av另类精品一区二区| 一区三区视频| 另类春色校园亚洲| 亚洲第一中文字幕| 欧美成年人在线观看| 亚洲人成在线观看一区二区| 母乳一区在线观看| 亚洲国产专区校园欧美| 欧美国产精品一区| 日韩亚洲成人av在线| 欧美三级电影一区| 亚洲影视在线| 国产一区二区久久久| 久久久久久久久蜜桃| 亚洲第一区中文99精品| 欧美 日韩 国产一区二区在线视频 | 小黄鸭精品密入口导航| 国产精品入口日韩视频大尺度| 亚洲一区二区免费视频| 国产精品一区视频网站| 亚洲伊人久久综合| 国产精品亚洲综合一区在线观看| 亚洲欧美日韩国产成人| 国产一区二区三区四区五区美女| 久久这里只有精品视频首页| 亚洲人妖在线| 欧美三日本三级三级在线播放| 亚洲欧美久久久| 韩国欧美一区| 欧美黄色片免费观看| 这里只有精品视频在线| 国产一区清纯| 欧美激情一区二区| 新狼窝色av性久久久久久| 在线观看成人小视频| 欧美亚男人的天堂| 久久天天躁狠狠躁夜夜av| 一本一本a久久| 国产一区二区三区久久久久久久久| 美日韩在线观看| 亚洲一区在线免费| 亚洲大胆女人| 国产精品视频第一区| 欧美96在线丨欧| 亚洲欧美日韩成人| 亚洲人屁股眼子交8| 国产深夜精品| 欧美日韩国产精品一区| 久久裸体艺术| 午夜精品偷拍| 亚洲精品四区| 在线免费观看日韩欧美| 国产美女扒开尿口久久久| 欧美不卡三区| 久久精品国产亚洲一区二区三区 | 在线成人国产| 国产精品久久久久久户外露出| 久久嫩草精品久久久久| 亚洲主播在线观看| 99精品国产在热久久婷婷| 亚洲大片在线| 韩国一区二区三区美女美女秀| 国产精品毛片a∨一区二区三区|国| 欧美激情网友自拍| 免费人成精品欧美精品| 久久米奇亚洲| 久久久久久自在自线| 欧美在线高清| 久久国产精品一区二区| 欧美在线3区| 欧美一级夜夜爽| 午夜久久一区| 久久成人av少妇免费|