视频元素在富文本编辑器中的光标问题

视频元素在富文本编辑器中的光标问题

视频元素插入到富文本编辑器后,光标出现在下方,按退格键会删除视频。原因是视频元素启用了交互控件(controls),被视为可聚焦的块级元素,而图片元素被当作原子内联内容(类似一个字符),浏览器对其有特殊的光标处理规则。

解决方案

方法一:禁用视频的可编辑性并添加零宽空格

为视频元素添加contenteditable="false"属性,并在其后插入零宽空格占位符。

html 复制代码
<video controls contenteditable="false"></video><span>&#8203;</span>

方法二:使用figure包裹视频并添加空段落

将视频包裹在figure标签中,并在其后紧跟一个空段落。

html 复制代码
<figure>
  <video controls></video>
</figure>
<p><br></p>

方法三:内联显示视频并添加零宽空格

将视频设置为内联块级元素,并在其后添加零宽空格。

html 复制代码
<video controls style="display:inline-block;"></video><span>&#8203;</span>

实现细节

  • 零宽空格&#8203;)是一个不可见的占位符,用于确保光标可以停留在视频右侧。
  • **contenteditable="false"**禁止视频元素被直接编辑,避免退格键误删。
  • figure标签语义化包裹视频,适合复杂内容场景。
  • 内联块级显示将视频模拟为类似图片的行为,但需注意控件交互可能受限。

推荐方案

对于需要保留视频交互性的场景,推荐方法二figure+空段落),既保持语义清晰,又能避免光标问题。若需简化实现,方法一方法三亦可快速解决问题。

相关推荐
进击的野人16 小时前
Vue 组件与原型链:VueComponent 与 Vue 的关系解析
前端·vue.js·面试
馬致远16 小时前
Vue todoList案例 优化之本地存储
前端·javascript·vue.js
请叫我聪明鸭16 小时前
CSS实现单行、多行文本超长显示 / 不超长隐藏、悬浮窗超长展示/不超长隐藏、悬浮窗手动控制样式
前端·javascript·css
blackorbird16 小时前
苹果修复了两个在定向攻击中被利用的Webkit漏洞,其中一个与谷歌ANGLE漏洞同源
前端·webkit
席之郎小果冻16 小时前
【04】【创建型】【聊一聊,建造者模式】
java·前端·建造者模式
风无雨16 小时前
在 React 中实现数学公式显示:使用 KaTeX 和 react-katex
前端·react.js·前端框架
二两锅巴17 小时前
📺 无需Electron!前端实现多显示器浏览器窗口精准控制与通信
前端
炸土豆17 小时前
防抖节流里的this传递
前端·javascript
用户40993225021217 小时前
Vue3中动态样式数组的后项覆盖规则如何与计算属性结合实现复杂状态样式管理?
前端·ai编程·trae
山璞17 小时前
Flutter3.32 中使用 webview4.13 与 vue3 项目的 h5 页面通信,以及如何调试
前端·flutter