检测可编辑div的可编辑子元素的键盘松开事件

14

目标:将一个 keydown 事件处理程序附加到 contenteditable div 的 contenteditable span 子元素上。

问题:如果您在 span 中键入,则会触发父级事件而不是子元素。我想要的是子元素触发,这样我就可以抓取文本。我只想要那个 contenteditable 子元素,因为会有很多个。

下面是 HTML/JS 代码,fiddle 链接在这里: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
});

**注意:事件处理委托给文档,因为元素是动态添加的。


请查看以下内容(可能是您需要的):https://dev59.com/SHM_5IYBdhLWcg3w8H82 - Duncan
2
我刚刚发现了这个问题,我认为这个更相关:https://dev59.com/QVTTa4cB1Zd3GeqPtYtB ,虽然看起来像是一个hack... 我认为这是一个bug。 - Joshua Robinson
1个回答

9

这是一个bug。FF23和CHROME29(在linux上,没有vm所以无法测试IE)确认了解决方法。你必须将包装span设置为contenteditable false,不能只省略声明contenteditable属性,这太荒谬了。解决方法可以参考Keypress event on nested content editable (jQuery)

这里是fiddle:http://jsfiddle.net/aBYpt/14/

HTML

<div class="parent" contenteditable="true">
    Parent div text.

    <span contenteditable="false">
        <span class="child" contenteditable="true">First child span text.</span>
    <span contenteditable="false">
        <span class="child" contenteditable="true">Second child span text.</span>
    </span>
</div>

<div id="console"></div>

JavaScript/jQuery

$(document).on( 'keyup', '.parent', function() {
    //do stuff
    $('#console').html( 'Parent keyup event fired.' );
});

$(document).on( 'keyup', '.child', function(e) {
    //do stuff
    $('#console').html( 'Child keyup event fired.' );
    e.stopPropagation();
});

2
我不同意这是一个错误:键盘事件只会在能够接收焦点的元素上触发,包括输入框和可编辑内容元素。可编辑元素内部的元素不符合条件。你可以从浏览器的选择对象中推断出包含插入符号的元素。 - Tim Down
1
这不是无关紧要的话题。我承认我没有详细定义我的术语(比如这个“editing host”的定义),但我希望我的观点是清晰的。可以接收焦点的元素可以触发键盘事件。在一个contenteditable元素内部,如果没有任何具有contenteditable =“false”的元素,则该元素不能接收焦点,因此不会生成键盘事件。 - Tim Down
这个答案存在文本选择问题。我无法连续选择父级和子级文本。 - Ankur Gupta

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接