• react-quill富文本 中文输入法触发change问题


    使用的富文本是编辑器 react-quill

    需求:

    点击按钮插入自定义颜色文字,然后手动输入为正常颜色。

    问题:

    quill组件把带颜色的字体创建个dom, 临近的文字都会整合进一个dom中,导致输入的文字和插入的带颜色 都统一成一个颜色了。

    中文输入拼音阶段就开始触发change事件,在转换文本时会把拼音和汉字混杂出现,结果不正确。

    解决方案:

    绑定compositionstart,compositionend 事件,可监听到非直接输入的输入法输入状态,结束时机准确。

    设置个状态,通过判断状态区分 中/英文输入法区别,正确处理逻辑。

    1. // 设置个状态,表示当前是否是非直接输入法输入(如中文,有拼音阶段)
    2. let editorIsChineseStatus = false
    3. useEffect(() => {
    4. const editorDom = document.querySelector('.ql-editor')
    5. if (!editorDom) return
    6. editorDom.addEventListener('compositionstart',function () {
    7. // 当前是非直接输入法输入
    8. editorIsChineseStatus = true
    9. },
    10. false
    11. )
    12. editorDom?.addEventListener('compositionend',function (e) {
    13. // 非直接输入法输入结束
    14. editorIsChineseStatus = false
    15. // 处理逻辑
    16. todo()
    17. },
    18. false
    19. )
    20. }, [])
    21. const editorChange = () => {
    22. // 直接输入法输入(英文,可直接输入)
    23. if (!editorIsChineseStatus) {
    24. // 处理英文输入逻辑
    25. todo2()
    26. }
    27. }

  • 相关阅读:
    956. 最高的广告牌
    2、CKA-简单搭建K8s集群
    带头双向循环链表
    韩顺平java课程527 -531速记笔记
    使用Spring+Postman实现数据交互
    必备元器件知识1——电阻
    Oracle中实现获取指定表名称批量修改表中的字段类型
    Jmeter常用函数用法详解
    设计模式---抽象工厂模式
    类的五大成分(Java)
  • 原文地址:https://blog.csdn.net/bangbDIV/article/details/132724196