フロントエンドの業務でjQueryで動的に追加した要素にクリックイベントが発火しないという問題に直面することが時々あります。
本記事では、クリックイベントが発火しない原因と対処方法について解説します。
クリックイベントが発火しないサンプルコード
以下のコードは、body要素の先頭に動的にbutton要素を追加し、クリックイベントを設定しています。
動的に追加したボタンをクリックすると、「ボタンがクリックされました!」というアラートが表示されるはずですが、クリックイベントが発火しません。
- <!DOCTYPE html>
- <html lang="ja">
- <head>
- <meta charset="UTF-8">
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
- <title>【jQuery】クリックイベント</title>
- </head>
- <body>
- <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.0/jquery.min.js"></script>
- <script>
- $('#myButton').on('click', function() {
- alert('ボタンがクリックされました!');
- });
- // 動的に追加するボタン要素
- let button = '<button id="myButton">クリック</button>';
- // ボタンを body の先頭に追加
- $(button).prependTo($('body'));
- </script>
- </body>
- </html>
クリックイベントが発火しない原因
jQueryで動的に追加された要素に対して直接クリックイベントを設定しても、クリックイベントは新しい要素に適用されません。
これは、jQueryがクリックイベントを設定する際に、その時点で存在する要素に対してのみ行うためです。
クリックイベントが発火しないときの対処方法
クリックイベントが発火しない例で記載している、$('#myButton').on('click', function() {部分を$(document).on('click', '#myButton', function() {と書き換えることで、jQueryで動的に追加した要素にクリックイベントを設定できます。
- <!DOCTYPE html>
- <html lang="ja">
- <head>
- <meta charset="UTF-8">
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
- <title>【jQuery】クリックイベント</title>
- </head>
- <body>
- <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.0/jquery.min.js"></script>
- <script>
- $(document).on('click', '#myButton', function() {
- alert('ボタンがクリックされました!');
- });
- // 動的に追加するボタン要素
- let button = '<button id="myButton">クリック</button>';
- // ボタンを body の先頭に追加
- $(button).prependTo($('body'));
- </script>
- </body>
- </html>
documentとは?
documentは、HTMLドキュメント全体を指すオブジェクトです。
具体的には、documentオブジェクトはウェブページのDOM(Document Object Model)ツリー全体を表しています。
$(document).on('click', '#myButton', function() {とすることで、HTMLドキュメント全体に対してクリックイベントリスナーを設定しています。
クリックイベントが発生したときに特定の要素(今回場合は、#myButton)にマッチするかどうかをチェックします。
documentオブジェクトを使用することで、ドキュメント全体に対してイベントリスナーを設定できるため、ページ内のどの要素に対しても柔軟にイベントを処理できるようになります。
HTMLとCSSの知識がありJavaScriptを学びたいという方におすすめの1冊
JavaScriptのフロントエンドエンジニアを目指している方におすすめの1冊

もみじ
この本はJavaScript初心者からフロントエンドエンジニアを目指す方にぴったりの1冊です。
非同期処理やAJAXなど、現代の開発で必要なスキルがわかりやすく解説されており、実務で役立つスキルを学ぶことができます。

もみじ
HTMLとCSSの知識がありJavaScriptを学びたいという方に入門書としておすすめの書籍です。
実務で役立つサンプルを手を動かしながら学ぶことができ、実践的なスキルを身に付けることができます。