亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript之事件委托實(shí)例(附原生js和jQuery代碼)

 更新時(shí)間:2017年07月22日 09:59:36   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇JavaScript之事件委托實(shí)例(附原生js和jQuery代碼)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

事件委托的原理依賴(lài)于事件冒泡,可以通過(guò)給父元素的事件委托來(lái)確定是哪個(gè)子元素觸發(fā)了事件從而做一系列操作。

使用事件委托的優(yōu)點(diǎn)

1、操作子元素時(shí)不用一一遍歷,可以根據(jù)事件觸發(fā)的對(duì)象而進(jìn)行相應(yīng)操作

dom結(jié)構(gòu)如下:

<ul id = "oUl">
 <li class = "item"></li>
 <li class = "item"></li>
 <li class = "item"></li>
 <li class = "item"></li> 
 <li class = "item"></li>
</ul>

當(dāng)li被點(diǎn)擊時(shí),打印該li的值。

在我們還沒(méi)有學(xué)事件委托的時(shí)候我們會(huì)遍歷所有l(wèi)i并給它們添加一個(gè)click事件,比如這樣:

var aLi = document.getElementsByTagName('li');

for(var i = 0; i < aLi.length; i++) // 遍歷li
 aLi[i].addEventListener('click', function() { //給每個(gè)li添加事件
 console.log(this.innerHTML); 
 });

學(xué)了事件委托之后js原生代碼如下:

var oUl = document.getElementById('oUl');

oUl.addEventListener('click', function(ev) {
 ev = ev||window.event;
 var tag = ev.target; // 觸發(fā)事件的對(duì)象保存在事件的target里面
 console.log(tag.innerHTML);
})

jQuery代碼如下:

$('#oUl').on('click', '.item', function() { 
 console.log($(this).html()); // this指向oUl中觸發(fā)了click事件并且class為item的子元素
})

相比之下,事件委托只需要獲取父元素并且不需要遍歷li,效率提高了不少。

2、將事件委托給父元素后,動(dòng)態(tài)創(chuàng)建(刪除)的子元素不用重新綁定(解綁)事件,實(shí)現(xiàn)了元素與事件的同步更新

在以往的js事件監(jiān)聽(tīng)中,用js動(dòng)態(tài)創(chuàng)建的子元素是沒(méi)有事件的,必須重新為它們綁定事件,但是用事件委托就不用這么麻煩了,不需要重新綁定事件依舊可以實(shí)現(xiàn)事件監(jiān)聽(tīng)。

當(dāng)然事件綁定也是有弊端的,因?yàn)樗蕾?lài)于事件冒泡,如果不支持冒泡那么就不能實(shí)現(xiàn)事件綁定了,不過(guò)我認(rèn)為這種幾率還是不高的。還有就是會(huì)發(fā)生事件誤判,比如頁(yè)面中的button1和button2的作用是點(diǎn)擊時(shí)彈出值,而button3的作用是點(diǎn)擊是頁(yè)面變色,這三個(gè)button的同一個(gè)事件實(shí)現(xiàn)功能不同,當(dāng)你將click事件委托給它們共同的父元素那么就會(huì)出現(xiàn)事件誤判。

所以我認(rèn)為事件委托是發(fā)生在一個(gè)子集合的事件功能相同的情況下,如果不相同則不要使用事件委托,以免弄巧成拙。

在實(shí)際開(kāi)發(fā)中,掌握事件綁定對(duì)于代碼的規(guī)范性以及效率會(huì)有一定提高,總的來(lái)說(shuō)利大于弊。

以上這篇JavaScript之事件委托實(shí)例(附原生js和jQuery代碼)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 指定區(qū)域的圖片自動(dòng)按比例縮小的js代碼(防止頁(yè)面被圖片撐破)

    指定區(qū)域的圖片自動(dòng)按比例縮小的js代碼(防止頁(yè)面被圖片撐破)

    有時(shí)候我們更新的內(nèi)容,有很多的大圖片,就會(huì)導(dǎo)致頁(yè)面變形或看不到全圖。一般情況我們用css的max-width控制,但有些瀏覽器不支持,我們也可以用js做個(gè)補(bǔ)充
    2014-02-02
  • 淺析JavaScript預(yù)編譯和暗示全局變量

    淺析JavaScript預(yù)編譯和暗示全局變量

    這篇文章主要介紹了JavaScript預(yù)編譯和暗示全局變量的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)JavaScript,感興趣的朋友可以了解下
    2020-09-09
  • 基于JavaScript實(shí)現(xiàn)移動(dòng)端無(wú)限加載分頁(yè)

    基于JavaScript實(shí)現(xiàn)移動(dòng)端無(wú)限加載分頁(yè)

    這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)移動(dòng)端無(wú)限加載分頁(yè),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • JavaScript實(shí)現(xiàn)郵箱后綴提示功能的示例代碼

    JavaScript實(shí)現(xiàn)郵箱后綴提示功能的示例代碼

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)郵箱后綴提示功能的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • JS Input里添加小圖標(biāo)的兩種方法

    JS Input里添加小圖標(biāo)的兩種方法

    大家在做網(wǎng)站的時(shí)候,經(jīng)常需要在input里面添加小圖標(biāo)功能,看似功能很簡(jiǎn)單,但是實(shí)現(xiàn)起來(lái)還是有點(diǎn)技巧的,下面小編給大家介紹下JS Input里添加小圖標(biāo)的兩種方法,需要的朋友參考下吧
    2017-11-11
  • js解決movebox移動(dòng)問(wèn)題

    js解決movebox移動(dòng)問(wèn)題

    這篇文章主要為大家詳細(xì)介紹了js解決movebox移動(dòng)問(wèn)題,取消圖片默認(rèn)拖動(dòng)事件,感興趣的小伙伴們可以參考一下
    2016-03-03
  • JavaScript實(shí)現(xiàn)點(diǎn)擊圖片換背景

    JavaScript實(shí)現(xiàn)點(diǎn)擊圖片換背景

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)點(diǎn)擊圖片換背景,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • php輸出全部gb2312編碼內(nèi)的漢字方法

    php輸出全部gb2312編碼內(nèi)的漢字方法

    下面小編就為大家?guī)?lái)一篇php輸出全部gb2312編碼內(nèi)的漢字方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-03-03
  • 利用Vconsole和Fillder進(jìn)行移動(dòng)端抓包調(diào)試方法

    利用Vconsole和Fillder進(jìn)行移動(dòng)端抓包調(diào)試方法

    這篇文章主要介紹了利用Vconsole和Fillder進(jìn)行移動(dòng)端抓包調(diào)試,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-03-03
  • 原生javascript制作的拼圖游戲?qū)崿F(xiàn)方法詳解

    原生javascript制作的拼圖游戲?qū)崿F(xiàn)方法詳解

    這篇文章主要介紹了原生javascript制作的拼圖游戲?qū)崿F(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了JavaScript制作拼圖游戲的相關(guān)步驟、原理、實(shí)現(xiàn)方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2020-02-02

最新評(píng)論