目標: keydown イベント ハンドラーを contenteditable div の子である contenteditable スパンにアタッチします。
問題:スパンを入力すると、子イベントではなく親イベントがトリガーされます。私が欲しいのは、テキストをつかむことができるように、子供がトリガーすることです。たくさんあるので、私はそのコンテンツ編集可能な子供だけが欲しいです。
HTML/JS は以下にあり、フィドル リンクはここにあります: http://jsfiddle.net/aBYpt/4/
HTML
<div class="parent" contenteditable="true">
Parent div text.
<span class="child" contenteditable="true">First child span text.</span>
<span class="child" contenteditable="true">Second child span text.</span>
<span class="child" contenteditable="true">Third child span text.</span>
</div>
<div id="console"></div>
JavaScript/jQuery
$(document).on( 'keyup', '.parent', function() {
$('#console').html( 'Parent keyup event fired.' );
//do stuff
});
$(document).on( 'keyup', '.child', function() {
$('#console').html( 'Child keyup event fired.' );
//do stuff
});
**注: 要素は動的に追加されるため、イベント処理はドキュメントに委譲されます。