在 contenteditable 编辑器中,如何使用 Shift+Enter 保持结构完整?

在 contenteditable 编辑器中,如何使用 Shift+Enter 保持结构完整?

在 contenteditable 编辑器内按 shift+enter 后如何保持结构完整

在 contenteditable="true" 属性的编辑框中,使用 Shift+Enter 换行后,文本内容可能会出现混乱的结构。这是因为默认情况下,浏览器会在换行处生成
标签,从而导致段落被分成多个行。

解决方案

为了解决这个问题,可以修改 keyDown 事件处理函数,使之在按 Shift+Enter 时执行以下步骤:

  1. 阻止默认行为(即生成
    标签)。
  2. 执行 "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 保持结构完整?的详细内容,更多请关注硕下网其它相关文章!