使用contenteditable=”true”的编辑框时,Shift+Enter换行容易导致html结构混乱。本文提供解决方案,避免此问题影响用户体验。
问题根源在于contenteditable编辑框默认的换行行为。 为了解决这个问题,我们需要拦截Shift+Enter的默认行为,并以编程方式插入有序的段落。 利用JavaScript的keydown事件监听器,当检测到Shift+Enter组合键时,阻止默认行为,然后插入新的段落元素。
以下代码示例演示了如何实现:
<meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> #editable { width: 300px; height: 300px; border: 1px solid #ccc; padding: 10px; } </style> <div contenteditable="true" id="editable" oninput="inputText()" onkeydown="keyDown(Event)"></div> <script> function keyDown(event) { if (event.shiftKey && event.keyCode === 13) { event.preventDefault(); document.execCommand('insertParagraph'); return false; } document.execCommand('formatblock', false, '<p>'); } function inputText() { if (document.getSelection().focusNode.data !== undefined) { let currentElement = document.getSelection().focusNode.parentNode; console.log(currentElement.innerHTML); } } </script>
代码中,keyDown函数监听keydown事件。当检测到Shift+Enter ( event.shiftKey && event.keyCode === 13 ),event.preventDefault()阻止默认行为,document.execCommand(‘insertParagraph’)插入一个新的段落元素。 inputText 函数用于监控输入内容变化(这里只是示例,可以根据实际需求修改或删除)。
此解决方案已在chrome 120.0.6099.201 (Official Build) (64-bit) (cohort: Control)版本中测试有效。其他浏览器或版本可能需要调整。 请注意,document.execCommand已被部分浏览器弃用,建议使用更现代化的dom操作方法进行替换,以确保更好的兼容性。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END