在 contenteditable 编辑器内按 shift+enter 后如何保持结构完整
在 contenteditable="true" 属性的编辑框中,使用 Shift+Enter 换行后,文本内容可能会出现混乱的结构。这是因为默认情况下,浏览器会在换行处生成
标签,从而导致段落被分成多个行。
解决方案
为了解决这个问题,可以修改 keyDown 事件处理函数,使之在按 Shift+Enter 时执行以下步骤:
下面是修改后的代码:
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 保持结构完整?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号