首頁 >web前端 >js教程 >js中的事件委託

js中的事件委託

小云云
小云云原創
2018-03-14 16:59:071676瀏覽

本文主要和大家分享js中的事件委託實例詳解,我們主要和大家分享兩個內容1.事件委託的原理以及優缺點2. 手寫原生js實現事件代理,並要求相容瀏覽器。

Q:事件的委託(代理Delegated Events)的原理以及優缺點

A:委託(代理)事件是那些被綁定到父級元素的事件,但是只有當滿足一定匹配條件時才會被挪。這是靠事件的冒泡機制來實現的,

#優點是:

(1)可以大量節省記憶體佔用,減少事件註冊,例如在table上代理所有td的click事件就非常棒 

(2)可以實現當新增子物件時無需再次對其綁定事件,對於動態內容部分尤為合適

缺點是:

事件代理程式的應用程式常用應該僅限於上述需求下,如果把所有事件都用代理就可能會出現事件誤判,即本不應用觸發事件的被綁上了事件。

範例:

#
var toolbar = document.querySelector(".toolbar");
toolbar.addEventListener("click", function(e) {
  var button = e.target;
  if(!button.classList.contains("active"))
    button.classList.add("active");
  else
    button.classList.remove("active");
});



點擊button元素會冒泡到UL.toolbar元素,使用了e.target來定位到目前點擊的button。

Q:手寫原生js實作事件代理,並要求相容瀏覽器

A:其實就是考核對事件物件e的了解程度,以及在IE下對應的屬性名。

查看Demo

function delegateEvent(interfaceEle, selector, type, fn) {// ============ 简单的事件委托
    if(interfaceEle.addEventListener){
    interfaceEle.addEventListener(type, eventfn);
    }else{
    interfaceEle.attachEvent("on"+type, eventfn);
    }
    function eventfn(e){
    var e = e || window.event;    
    var target = e.target || e.srcElement;
 
  
 //如果目标元素与选择器匹配则执行函数
    if (matchSelector(target, selector)) {
            if(fn) {
 //将fn内部的this指向target(在此之前this都是指向的绑定事件的元素即interfaceEle)
                fn.call(target, e); 
            }
        }
    }
}
/**
 * only support #id, tagName, .className
 * and it's simple single, no combination
 */
//比较函数:判断事件的作用目标是否与选择器匹配;匹配则返回true
function matchSelector(ele, selector) {
    //
 如果选择器为ID
    if (selector.charAt(0) === "#") {
            
        return ele.id === selector.slice(1);
   
    }
 
     //charAt(0),返回索引为0的字符
 
   //slice(a,b),从已有的数组或字符串返回从索引从a处开始,截取到索引b之前的子数组或子字符串;
    //如果选择器为Class
    if (selector.charAt(0) === ".") {
        return (" " + ele.className + " ").indexOf(" " + selector.slice(1) + " ") != -1;
    }
    //
 如果选择器为tagName
    return ele.tagName.toLowerCase() === selector.toLowerCase();
}
//toLowerCase()将字符串转换成小写
//调用
var op = document.getElementById("op");
delegateEvent(op,"a","click",function(){
    alert("1");
})

相關推薦:

JS事件委託實例詳解

以上是js中的事件委託的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn