web関連

【jquery】.click()と.on()の違い

ふと気になったんだけど、.click(function().on('click', function()ってどっち使えばいいんだろうと思ったので備忘録

.click()と.on()の違い

使用するHTMLコード

<div class="btn">これはボタン</div>

基本使い方は一緒

$('button').click(function() {
    alert('ボタンがクリックされたよー');
});

$('button').on('click', function() {
    alert('ボタンがクリックされたよー');
});
正常に動作

jqueryで静的に追加したボタンでもどっちも挙動は一緒

jQuery(function($){
	$('.btn').after('<div class="add">追加されたボタン</div>')
	$('.add').click(function() {
	    alert('ボタンがクリックされたよー');
	});

	$('.add').on('click', function() {
	    alert('ボタンがクリックされたよー');
	});
});
これも同じくどっちも正常に動作

動的な要素に対してクリックイベントを仕込むときは注意

クリックして追加される要素に対してさらにクリックイベントを仕込むときは注意が必要

jQuery(function($){
	$('.btn').click(function() {
		$(this).after('<div class="add">追加されたボタン</div>')
	});
	// × 動かない
	$('.add').click(function() {
	    alert('ボタンがクリックされたよー');
	});
	// ○ 動くけど書き換えが必要
	$('body').on('click' ,'.add', function() {
	    alert('ボタンがクリックされたよー');
	});
});

$('body').on('click' ,'.add', function()って書き換えてるけど
最初のDOM読み込み時に無い要素なので、クリックされたらbody要素の内の.addを見に行ってねって命令出してるみたい

こういう風に動的に何かを追加する必要があれば.on()を使ったほうがよさげ

jQueryのclick()で処理を実行&無効にする方法

【jQuery入門】on()によるイベント処理の使い方まとめ!

動的な要素にクリックイベントを仕込む時以外はどっちでもよさそうね

今まで調べてこなかったけど普通に「へー」って感心したわ
勉強って大事ね

Leave a Comment

入力エリアすべてが必須項目です。メールアドレスが公開されることはありません。

内容をご確認の上、送信してください。