当前位置:   article > 正文

vue项目使用vue-quill-editor,光标位置控制(已解决)_vue-quill-editor 编辑光标老是往前输入

vue-quill-editor 编辑光标老是往前输入

查了网上很多资料使用,都没有解决,故记录在此

全局引入

  1. import Vue from 'vue'
  2. import VueQuillEditor from 'vue-quill-editor'
  3. // require styles
  4. import 'quill/dist/quill.core.css'
  5. import 'quill/dist/quill.snow.css'
  6. import 'quill/dist/quill.bubble.css'
  7. Vue.use(VueQuillEditor)

在页面上写组件

  1. <quill-editor
  2. v-model="content"
  3. ref="myQuillEditor"
  4. :options="editorOption"
  5. @blur="onEditorBlur($event)"
  6. @focus="onEditorFocus($event)"
  7. @change="onEditorChange($event)"
  8. @ready="onEditorReady($event)">
  9. </quill-editor>

配置option

  1. editorOption: {
  2. modules: {
  3. toolbar: [
  4. ['bold', 'italic', 'underline', 'strike'], // 加粗 斜体 下划线 删除线
  5. ['blockquote', 'code-block'], // 引用 代码块
  6. [{ header: 1 }, { header: 2 }], // 1、2 级标题
  7. [{ list: 'ordered' }, { list: 'bullet' }], // 有序、无序列表
  8. [{ script: 'sub' }, { script: 'super' }], // 上标/下标
  9. [{ indent: '-1' }, { indent: '+1' }], // 缩进
  10. [{ direction: 'rtl' }], // 文本方向
  11. [{ size: ['12', '14', '16', '18', '20', '22', '24', '28', '32', '36'] }], // 字体大小
  12. [{ header: [1, 2, 3, 4, 5, 6] }], // 标题
  13. [{ color: [] }, { background: [] }], // 字体颜色、字体背景颜色
  14. // [{ font: ['songti'] }], // 字体种类
  15. [{ align: [] }], // 对齐方式
  16. ['clean'], // 清除文本格式
  17. ['image', 'video'] // 链接、图片、视频
  18. ]
  19. },
  20. placeholder: '请输入正文'
  21. },

给工具栏鼠标悬停加上中文释义

找到元素可以看到,每一个tool都有一个class, 这个的原理就是先把所有的class列出来,然后根据class获取元素,给它加上title属性就可以了

  1. const titleConfig = [
  2. { Choice: '.ql-insertMetric', title: '跳转配置' },
  3. { Choice: '.ql-bold', title: '加粗' },
  4. { Choice: '.ql-italic', title: '斜体' },
  5. { Choice: '.ql-underline', title: '下划线' },
  6. { Choice: '.ql-header', title: '段落格式' },
  7. { Choice: '.ql-strike', title: '删除线' },
  8. { Choice: '.ql-blockquote', title: '块引用' },
  9. { Choice: '.ql-code', title: '插入代码' },
  10. { Choice: '.ql-code-block', title: '插入代码段' },
  11. { Choice: '.ql-font', title: '字体' },
  12. { Choice: '.ql-size', title: '字体大小' },
  13. { Choice: '.ql-list[value="ordered"]', title: '编号列表' },
  14. { Choice: '.ql-list[value="bullet"]', title: '项目列表' },
  15. { Choice: '.ql-direction', title: '文本方向' },
  16. { Choice: '.ql-header[value="1"]', title: 'h1' },
  17. { Choice: '.ql-header[value="2"]', title: 'h2' },
  18. { Choice: '.ql-align', title: '对齐方式' },
  19. { Choice: '.ql-color', title: '字体颜色' },
  20. { Choice: '.ql-background', title: '背景颜色' },
  21. { Choice: '.ql-image', title: '图像' },
  22. { Choice: '.ql-video', title: '视频' },
  23. { Choice: '.ql-link', title: '添加链接' },
  24. { Choice: '.ql-formula', title: '插入公式' },
  25. { Choice: '.ql-clean', title: '清除字体格式' },
  26. { Choice: '.ql-script[value="sub"]', title: '下标' },
  27. { Choice: '.ql-script[value="super"]', title: '上标' },
  28. { Choice: '.ql-indent[value="-1"]', title: '向左缩进' },
  29. { Choice: '.ql-indent[value="+1"]', title: '向右缩进' },
  30. { Choice: '.ql-header .ql-picker-label', title: '标题大小' },
  31. { Choice: '.ql-header .ql-picker-item[data-value="1"]', title: '标题一' },
  32. { Choice: '.ql-header .ql-picker-item[data-value="2"]', title: '标题二' },
  33. { Choice: '.ql-header .ql-picker-item[data-value="3"]', title: '标题三' },
  34. { Choice: '.ql-header .ql-picker-item[data-value="4"]', title: '标题四' },
  35. { Choice: '.ql-header .ql-picker-item[data-value="5"]', title: '标题五' },
  36. { Choice: '.ql-header .ql-picker-item[data-value="6"]', title: '标题六' },
  37. { Choice: '.ql-header .ql-picker-item:last-child', title: '标准' },
  38. { Choice: '.ql-size .ql-picker-item[data-value="small"]', title: '小号' },
  39. { Choice: '.ql-size .ql-picker-item[data-value="large"]', title: '大号' },
  40. { Choice: '.ql-size .ql-picker-item[data-value="huge"]', title: '超大号' },
  41. { Choice: '.ql-size .ql-picker-item:nth-child(2)', title: '标准' },
  42. { Choice: '.ql-align .ql-picker-item:first-child', title: '居左对齐' },
  43. { Choice: '.ql-align .ql-picker-item[data-value="center"]', title: '居中对齐' },
  44. { Choice: '.ql-align .ql-picker-item[data-value="right"]', title: '居右对齐' },
  45. { Choice: '.ql-align .ql-picker-item[data-value="justify"]', title: '两端对齐' }
  46. ]

然后在function中循环,找到元素,添加title,至于放在那个function根据具体情况看,反正得是在页面上已经渲染好元素之后,不然会获取不到元素,可以直接放在@ready的函数里面

  1. for (let item of titleConfig) {
  2. let tip = document.querySelector('.quill-editor ' + item.Choice)
  3. if (!tip) continue
  4. tip.setAttribute('title', item.title)
  5. }

给工具栏功能添加自定义事件

  1. editorOption: {
  2. modules: {
  3. toolbar: {
  4. container: [
  5. ['bold', 'italic', 'underline', 'strike'], // 加粗 斜体 下划线 删除线
  6. ['blockquote', 'code-block'], // 引用 代码块
  7. [{ header: 1 }, { header: 2 }], // 1、2 级标题
  8. [{ list: 'ordered' }, { list: 'bullet' }], // 有序、无序列表
  9. [{ script: 'sub' }, { script: 'super' }], // 上标/下标
  10. [{ indent: '-1' }, { indent: '+1' }], // 缩进
  11. [{ direction: 'rtl' }], // 文本方向
  12. [{ size: ['12', '14', '16', '18', '20', '22', '24', '28', '32', '36'] }], // 字体大小
  13. [{ header: [1, 2, 3, 4, 5, 6] }], // 标题
  14. [{ color: [] }, { background: [] }], // 字体颜色、字体背景颜色
  15. // [{ font: ['songti'] }], // 字体种类
  16. [{ align: [] }], // 对齐方式
  17. ['clean'], // 清除文本格式
  18. ['image', 'video'] // 链接、图片、视频
  19. ],
  20. handlers: {
  21. 'image': function (value) {
  22. if (value) { // value === true
  23. document.querySelector('.avatar-uploader input').click()
  24. } else {
  25. this.quill.format('image', false)
  26. }
  27. }
  28. }
  29. }
  30. },
  31. placeholder: '请输入正文'
  32. }

遇到的问题:

给editor设置默认值,光标位置在句首,无法显示在句尾:

附上官方文档地址:选区(selection) · Quill官方中文文档 · 看云

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/114675
推荐阅读
相关标签
  

闽ICP备14008679号