赞
踩
查了网上很多资料使用,都没有解决,故记录在此
全局引入
- import Vue from 'vue'
- import VueQuillEditor from 'vue-quill-editor'
-
- // require styles
- import 'quill/dist/quill.core.css'
- import 'quill/dist/quill.snow.css'
- import 'quill/dist/quill.bubble.css'
-
- Vue.use(VueQuillEditor)
在页面上写组件
- <quill-editor
- v-model="content"
- ref="myQuillEditor"
- :options="editorOption"
- @blur="onEditorBlur($event)"
- @focus="onEditorFocus($event)"
- @change="onEditorChange($event)"
- @ready="onEditorReady($event)">
- </quill-editor>
- editorOption: {
- modules: {
- toolbar: [
- ['bold', 'italic', 'underline', 'strike'], // 加粗 斜体 下划线 删除线
- ['blockquote', 'code-block'], // 引用 代码块
- [{ header: 1 }, { header: 2 }], // 1、2 级标题
- [{ list: 'ordered' }, { list: 'bullet' }], // 有序、无序列表
- [{ script: 'sub' }, { script: 'super' }], // 上标/下标
- [{ indent: '-1' }, { indent: '+1' }], // 缩进
- [{ direction: 'rtl' }], // 文本方向
- [{ size: ['12', '14', '16', '18', '20', '22', '24', '28', '32', '36'] }], // 字体大小
- [{ header: [1, 2, 3, 4, 5, 6] }], // 标题
- [{ color: [] }, { background: [] }], // 字体颜色、字体背景颜色
- // [{ font: ['songti'] }], // 字体种类
- [{ align: [] }], // 对齐方式
- ['clean'], // 清除文本格式
- ['image', 'video'] // 链接、图片、视频
- ]
- },
- placeholder: '请输入正文'
- },
找到元素可以看到,每一个tool都有一个class, 这个的原理就是先把所有的class列出来,然后根据class获取元素,给它加上title属性就可以了
- const titleConfig = [
- { Choice: '.ql-insertMetric', title: '跳转配置' },
- { Choice: '.ql-bold', title: '加粗' },
- { Choice: '.ql-italic', title: '斜体' },
- { Choice: '.ql-underline', title: '下划线' },
- { Choice: '.ql-header', title: '段落格式' },
- { Choice: '.ql-strike', title: '删除线' },
- { Choice: '.ql-blockquote', title: '块引用' },
- { Choice: '.ql-code', title: '插入代码' },
- { Choice: '.ql-code-block', title: '插入代码段' },
- { Choice: '.ql-font', title: '字体' },
- { Choice: '.ql-size', title: '字体大小' },
- { Choice: '.ql-list[value="ordered"]', title: '编号列表' },
- { Choice: '.ql-list[value="bullet"]', title: '项目列表' },
- { Choice: '.ql-direction', title: '文本方向' },
- { Choice: '.ql-header[value="1"]', title: 'h1' },
- { Choice: '.ql-header[value="2"]', title: 'h2' },
- { Choice: '.ql-align', title: '对齐方式' },
- { Choice: '.ql-color', title: '字体颜色' },
- { Choice: '.ql-background', title: '背景颜色' },
- { Choice: '.ql-image', title: '图像' },
- { Choice: '.ql-video', title: '视频' },
- { Choice: '.ql-link', title: '添加链接' },
- { Choice: '.ql-formula', title: '插入公式' },
- { Choice: '.ql-clean', title: '清除字体格式' },
- { Choice: '.ql-script[value="sub"]', title: '下标' },
- { Choice: '.ql-script[value="super"]', title: '上标' },
- { Choice: '.ql-indent[value="-1"]', title: '向左缩进' },
- { Choice: '.ql-indent[value="+1"]', title: '向右缩进' },
- { Choice: '.ql-header .ql-picker-label', title: '标题大小' },
- { Choice: '.ql-header .ql-picker-item[data-value="1"]', title: '标题一' },
- { Choice: '.ql-header .ql-picker-item[data-value="2"]', title: '标题二' },
- { Choice: '.ql-header .ql-picker-item[data-value="3"]', title: '标题三' },
- { Choice: '.ql-header .ql-picker-item[data-value="4"]', title: '标题四' },
- { Choice: '.ql-header .ql-picker-item[data-value="5"]', title: '标题五' },
- { Choice: '.ql-header .ql-picker-item[data-value="6"]', title: '标题六' },
- { Choice: '.ql-header .ql-picker-item:last-child', title: '标准' },
- { Choice: '.ql-size .ql-picker-item[data-value="small"]', title: '小号' },
- { Choice: '.ql-size .ql-picker-item[data-value="large"]', title: '大号' },
- { Choice: '.ql-size .ql-picker-item[data-value="huge"]', title: '超大号' },
- { Choice: '.ql-size .ql-picker-item:nth-child(2)', title: '标准' },
- { Choice: '.ql-align .ql-picker-item:first-child', title: '居左对齐' },
- { Choice: '.ql-align .ql-picker-item[data-value="center"]', title: '居中对齐' },
- { Choice: '.ql-align .ql-picker-item[data-value="right"]', title: '居右对齐' },
- { Choice: '.ql-align .ql-picker-item[data-value="justify"]', title: '两端对齐' }
- ]
然后在function中循环,找到元素,添加title,至于放在那个function根据具体情况看,反正得是在页面上已经渲染好元素之后,不然会获取不到元素,可以直接放在@ready的函数里面
- for (let item of titleConfig) {
- let tip = document.querySelector('.quill-editor ' + item.Choice)
- if (!tip) continue
- tip.setAttribute('title', item.title)
- }
给工具栏功能添加自定义事件
- editorOption: {
- modules: {
- toolbar: {
- container: [
- ['bold', 'italic', 'underline', 'strike'], // 加粗 斜体 下划线 删除线
- ['blockquote', 'code-block'], // 引用 代码块
- [{ header: 1 }, { header: 2 }], // 1、2 级标题
- [{ list: 'ordered' }, { list: 'bullet' }], // 有序、无序列表
- [{ script: 'sub' }, { script: 'super' }], // 上标/下标
- [{ indent: '-1' }, { indent: '+1' }], // 缩进
- [{ direction: 'rtl' }], // 文本方向
- [{ size: ['12', '14', '16', '18', '20', '22', '24', '28', '32', '36'] }], // 字体大小
- [{ header: [1, 2, 3, 4, 5, 6] }], // 标题
- [{ color: [] }, { background: [] }], // 字体颜色、字体背景颜色
- // [{ font: ['songti'] }], // 字体种类
- [{ align: [] }], // 对齐方式
- ['clean'], // 清除文本格式
- ['image', 'video'] // 链接、图片、视频
- ],
- handlers: {
- 'image': function (value) {
- if (value) { // value === true
- document.querySelector('.avatar-uploader input').click()
- } else {
- this.quill.format('image', false)
- }
- }
- }
- }
- },
- placeholder: '请输入正文'
- }
遇到的问题:
给editor设置默认值,光标位置在句首,无法显示在句尾:
附上官方文档地址:选区(selection) · Quill官方中文文档 · 看云
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。