この記事では主に、js でのイベント委任の例について詳しく説明します。主に 2 つの内容を共有します。 1. イベント委任の原理と利点と欠点 2. 手書きのネイティブ JS はイベント プロキシを実装し、ブラウザーの互換性が必要です。 。
Q: イベント委任 (委任イベント) の原則と利点と欠点
A: 委任 (プロキシ) イベントは、親要素にバインドされているイベントですが、特定の一致条件が満たされた場合にのみ、移動しました。これは、イベント バブリング メカニズムによって実現されます。利点は次のとおりです。
(1) メモリ使用量を大幅に節約し、テーブル上のすべての TD クリック イベントをプロキシすることができます
。(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"); });
Q: イベントプロキシを実装するために手書きのネイティブjs、ブラウザとの互換性が必要
A: 実際には、IEでのイベントオブジェクトeと対応する属性名の理解を評価するためのものです。
デモを見る
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"); })
関連する推奨事項: