JavaScriptで後から追加した要素にイベントを割り当てる方法と挙動の違いについて
jQueryで後から追加した要素に対してイベントを割り当てる場合、いつもと異なる記述が必要になるがJavaScriptだとどうなるのか知らなかった。試したところonclick / addEventListenerどちらも動作したが微妙に挙動が異なった。その辺りをメモ。
対応方法
ソースコード
いずれの方法でも後から追加した要素に対してイベントの割り当てが可能。ただ、微妙に挙動が異なる。
<div id="test_area"></div>
<script type="text/javascript" src="https://code.jquery.com/jquery-3.7.1.min.js"></script>
<script>
document.querySelector(`#test_area`).innerHTML = `<button id="test_btn" onclick="clickFunc();">button</button>`;
function clickFunc(){
console.log(`click 1`);
}
document.querySelector(`#test_btn`).onclick = function() {
console.log(`click 2`);
}
document.querySelector(`#test_btn`).addEventListener(`click`, function() {
console.log(`click 3`);
});
document.querySelector(`#test_btn`).addEventListener(`click`, function() {
console.log(`click 4`);
});
</script>
挙動について
上記ソースコードを実行するとコンソールには「click 2」「click 3」「click 4」が表示される。
どうも1つ目のonclick属性、2つ目のclickプロパティについては上書きされる仕様みたい。そのため「click 1」が「click 2」に上書きされている。
addEventListenerの場合は上書きされず追加されるという挙動のため「click 3」「click 4」が表示される。
明確にイベントを上書きしたいという場合じゃない限りaddEventListenerを使用するのが無難かと思われる。
関連記事
-
-
Chart.jsで描写したグラフを画像としてダウンロードさせる方法
サイト内にChart.jsでグラフを描写し、ボタンやリンクをクリックすることで当 ...
-
-
JavaScript / PHPにて「lz-string」を用いてデータの圧縮・展開する方法
文字数が多いGETパラメータを送信したいというケースがあった。また、送信側はJa ...
-
-
フォームの入力・選択内容を自動保存してくれる「Garlicjs」プラグインの利用方法
お問い合わせページ等、フォームを設置したページで入力・選択した内容を保存したい。 ...
-
-
jQueryで指定した要素を簡単にフォーカスするfocusbleの使い方
divやspanなど指定した要素を簡単にフォーカスするjQueryプラグインがあ ...
-
-
JavaScriptで特定の範囲内から数値が被らずにランダムに取り出す方法
1位から20位のランキング内でJavaScriptを用いてランダムに表示させたか ...