ホームページ >ウェブフロントエンド >jsチュートリアル >JS を使用して動的要素にイベントを追加する方法
今回は、JSを使用して動的要素にイベントを追加する方法を紹介します。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>
実行効果:
たとえば、ループ内の li に追加された for イベントは、新しく追加された li にバインドできません。詳細な理由はここでは説明しません。では、これをどうやって解決するのでしょうか? 実際、その方法も簡単で、コードを直接入力するだけです。この記事では、中国語の Web サイトのその他の関連記事を参照してください。
推奨書籍:
実際のプロジェクトで jquery filter() を使用する方法nodejs+server.js を使用して Web サーバーを作成する以上がJS を使用して動的要素にイベントを追加する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。