2009年11月10日 #javascript jquery

多重bind

  • 検証:一つのボタンにイベントを多重バインドした時の動き
$(input).bind('click', function() {
  alert(1);
});
$(input).bind('click', function() {
  alert(2);
});
$(input).bind('click', function() {
  alert(3);
});
  • 出力:inputのボタンをクリックするとalertで1,2,3が次々と出る
  • 結論:バインドされた順番どおり実行

一括unbind

  • 検証:上記多数バインドされた要素に対し、一括でunbind
$(input).unbind('click');
  • 出力:なし
  • 結論:一括でunbindされた

特定のイベントのみunbind

  • 検証:多数bindしたイベントの中で、特定のイベントのみunbind

バインド時のファンクションをそのまま記述(失敗)

$(input).unbind('click', function() {
  alert(2);
});
  • 出力:1, 2, 3
  • 結論:失敗

ファンクションのリテラル(リファレンス)を通してunbind

function out1() {
  alert(1);
};
function out2() {
  alert(2);
};
function out3() {
  alert(3);
};
$(input).bind('click',out1);
$(input).bind('click',out2);
$(input).bind('click',out3);
$(input).unbind('click',out2)
  • 出力:1, 3
  • 結論:ファンクションのリテラル(リファレンス変数)を通して指定したイベントのみをunbindできる、しかしこれはあらかじめファンクションを定義しておかないと駄目

名前空間を用いてbind

$(input).bind('click.1', function() {
  alert(1);
});
$(input).bind('click.2', function() {
  alert(2);
});
$(input).bind('click.3', function() {
  alert(3);
});
$(input).unbind('click.2');
  • 出力:1, 3
  • 結論:bindの第一引数でevent.namespaceと名前空間を使えばうまくunbindできる

同じの名前空間で複数のイベントにbindされた際

$(input).bind('click.namespace', function() {});
$(input).bind('blur.namespace', function() {});
$(input).unbind('.namespace');
  • 結論:名前空間指定で一括でunbindできる

一つのイベントに複数の名前空間を登録

$(input).bind('click.1.2',  function() {});
// click.1.2の名前空間にたどり着ける
$(input).trigger('click.1');
// click.1.2名前空間にたどり着ける
$(input).unbind('click.2');
  • 結論:複数の名前空間のうち、任意の一つを使えばそのイベントを選択できる

公式サイト(英語):