// ============ 簡單的事件委託 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 odiv = document.getElementById( "oDiv" ); delegateEvent(odiv, "a" , "click" , function (){ alert( "1" ); }) |