处理wangEditor编辑器缩进问题

首行缩进处理方案总结

核心问题

  • 要求:首行缩进固定为两个中文字符宽度
  • 难点:字号变化、编辑器自动添加样式、增加/减少缩进功能冲突

解决思路

1. 精确测量方案
  • 问题:em、ic 等单位在字号变化时不够精确
  • 方案:使用 Canvas 动态测量字符宽度,转换为像素值

    复制代码
    // 测量中文字符宽度
    function measureCjkCharWidthPx(element) {
      // 查找第一个文本节点的实际字体大小
      // 使用 Canvas 测量字符宽度
      // 返回像素值
    }
2. 动态样式覆盖机制
  • 问题:编辑器自动添加 text-indent: 2em 行内样式,优先级高
  • 方案:使用 setProperty + !important 强制覆盖

    复制代码
      p.style.setProperty('text-indent', `${indentPx}px`, 'important');
    3. MutationObserver 监听策略
  • 监听内容:

  • text-indent 变化(覆盖编辑器自动添加)

  • font-size 变化(段落本身和段落内元素如 span)

  • class 变化(可能通过 CSS 类改变字号)

  • 防抖:延迟 50ms 处理,避免频繁触发

  • 识别变化类型:

  • 段落本身变化

  • 段落内元素(span)变化,需找到对应段落

4. 避免干扰
  • 问题:增加/减少缩进功能被干扰
  • 方案:
  • 不在 handleChange 中自动处理缩进
  • 只在 handleBlur 时处理
  • MutationObserver 不监听 margin-left/padding-left(编辑器的块级缩进)
5. 处理逻辑分层
复制代码
  function applyFirstLineIndentPx() {
    // 1. 排除列表、标题等
    // 2. 检测用户是否点击"减少缩进"(text-indent: 0)
    // 3. 检测是否有块级缩进(margin-left/padding-left > 0)
    // 4. 默认情况:测量字符宽度,设置为两字宽
  }

关键代码结构

复制代码
  // 1. 测量函数:动态获取字符宽度
  measureCjkCharWidthPx(element) → 像素值

  // 2. 应用函数:根据规则设置缩进
  applyFirstLineIndentPx() → 更新所有段落

  // 3. 监听机制:MutationObserver + 防抖
  observer.observe(editable, {
    attributes: true,
    attributeFilter: ['style', 'class'],
    attributeOldValue: true,
    subtree: true
  })

  // 4. 事件处理:只在失焦时处理
  handleBlur() → 延迟应用规则
相关推荐
山峰哥18 小时前
数据库工程与SQL调优——从索引策略到查询优化的深度实践
数据库·sql·性能优化·编辑器
Doro再努力19 小时前
Vim 快速上手实操手册:从入门到生产环境实战
linux·编辑器·vim
Doro再努力19 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
kun200310291 天前
如何用Obsidian+VSCode生成文案排版并发布到公众号
ide·vscode·编辑器
徐小夕@趣谈前端1 天前
拒绝重复造轮子?我们偏偏花365天,用Vue3写了款AI协同的Word编辑器
人工智能·编辑器·word
风一样的航哥1 天前
标题:从卡顿到流畅:深度剖析 Word 2013 与 Word 2021 处理高清图片文档的性能鸿沟
编辑器
冬奇Lab1 天前
一天一个开源项目(第14篇):CC Workflow Studio - 可视化AI工作流编辑器,让AI自动化更简单
人工智能·开源·编辑器
承渊政道1 天前
Linux系统学习【Linux基础开发工具】
linux·运维·笔记·学习·centos·编辑器
徐小夕@趣谈前端2 天前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
zhanglianzhao2 天前
Win 11 WSL 配置Claude code 并在VsCode中使用
ide·vscode·编辑器·claude·cladue code