Цель: Присоединить обработчик события keydown к содержательному контенту, который является дочерним элементом contenteditable div.
Проблема: Если вы вводите span, родительское событие запускается не дочерними. Я хочу, чтобы ребенок запускался, чтобы я мог захватить текст. Я только хочу, чтобы этот контент был доступен для детей, так как их будет много.
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
});
** Примечание. Обработка событий делегируется документу, поскольку элементы динамически добавляются.