今回は、JS がイベント委任を使用して要素にイベントを追加するときの 注意事項 について紹介します。以下に実際のケースを示しますので、見てみましょう。
日常の開発では js を介していくつかの要素を作成することがありますが、元の for ループ を使用して作成したノードにイベントを追加すると、うまく動作しないことがよくあります:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>js动态添加事件</title> </head> <body> <ul id="out-ul"> <li class="out-li">123</li> <li class="out-li">123</li> <li class="out-li">123</li> </ul> <button id="btn">添加</button> <script> document.getElementById('btn').addEventListener('click',function(){ var htmlFragment='<li>我是新增的li</li>'; var addLi=document.createElement('li'); addLi.innerHTML=htmlFragment; outUl.appendChild(addLi); },false); var outUl=document.getElementById('out-ul') var outLi=outUl.getElementsByClassName('out-li'); for(var i=0;i<outLi.length;i++){ outLi[i].onclick=function(){ alert(1); } } </script> </body> </html>
たとえば、イベントは、 for ループ 新たに追加した li にバインドすることはできません。詳細な理由はここでは説明しません。では、これをどうやって解決するのでしょうか? 実際、その方法は簡単で、イベント委任を通じてコードを直接入力するだけです。イベントをトリガーすることもできますが、jquery の詳細な方法はここでは紹介しません。ネイティブ js と jquery の解決原理は実際には同じです。皆さんはネイティブメソッドを理解していると思いますし、jquery メソッドもよく理解できると思います
この記事の事例を読んだ後は、メソッドを習得したと思います。さらに興味深い情報については、他の関連記事に注目してください。 PHP中国語ウェブサイトで!
推奨読書:
jquery での filter() メソッドの使用の詳細な説明 jquery での filter() メソッドの使用例の説明
以上がJS はイベント委任を使用して要素にイベントを追加しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。