在 contenteditable 编辑器中,如何使用 Shift+Enter 保持结构完整?
在 contenteditable 编辑器内按 shift+enter 后如何保持结构完整
在 contenteditable="true" 属性的编辑框中,使用 Shift+Enter 换行后,文本内容可能会出现混乱的结构。这是因为默认情况下,浏览器会在换行处生成
标签,从而导致段落被分成多个行。
解决方案
为了解决这个问题,可以修改 keyDown 事件处理函数,使之在按 Shift+Enter 时执行以下步骤:
- 阻止默认行为(即生成
标签)。 - 执行 "insertParagraph" 命令,在光标位置插入一个新的段落。
下面是修改后的代码:
function keyDown (event) { // 拦截 Shift+Enter if (event.shiftKey && event.keyCode === 13) { event.preventDefault(); document.execCommand('insertParagraph'); return false; } // 正常换行 document.execCommand('formatblock', false, '<p>'); }
注意事项
请注意,此解决方案在 Chrome 120.0.6099.201(官方版本)浏览器中进行了测试,其他浏览器或版本可能需要不同的处理方式。
以上就是在 contenteditable 编辑器中,如何使用 Shift+Enter 保持结构完整?的详细内容,更多请关注硕下网其它相关文章!