Vue中Quill富⽂本编辑器的使⽤教程
在项⽬中需要引⼊Quill⽂本编辑器,并且根据需求,需要⾃定义字体选项、图⽚拖拽上传和改变⼤⼩,所以根据Quill官⽹系统学习了⼀下,以下是我学习和研究的结果。
⼀、主题
Quill的富⽂本编辑器分为snow和bubble两种。
snow是有⼯具栏的,如下:
bubble是只有⽂本域的,如下:
那么具体如何选择
在vue项⽬中,具体引⼊Quill的⽂件中,需要使⽤哪种主题就写哪个。默认是snow主题的。
优秀的富文本编辑器
<script>
export default {
data:function(){
return{
editorOption:{
//theme:'bubble'
theme:'snow'
}
}
}
}
</script>
⼆、⾃定义⼯具栏toolbar
1、具体配置如下,需要哪个写哪个。
<script>
export default {
data:function(){
return{
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': ['small', false, 'large', 'huge'] }], // 字体⼤⼩
[{ 'header': [1, 2, 3, 4, 5, 6, false] }],    //⼏级标题
[{ 'color': [] }, { 'background': [] }],    // 字体颜⾊,字体背景颜⾊
[{ 'font': [] }],    //字体
[{ 'align': [] }],    //对齐⽅式
['clean'],    //清除字体样式
['image','video']    //上传图⽚、上传视频
]
},
theme:'snow'
}
}
}
}
</script>
其中color、background、font、align都是有默认值的,写⼀个空数据即可。如果想要⾃定义,请往下看。
2、⾃定义字体列表,加⼊⾃⼰需要的字体
(1)引⼊⼀个单独⾃定义的font.css⽂件(如下)在app.vue⽂件中,因为要在初始化的时候就引⼊才能覆盖掉默认的!!很重要
<template>
<div id="app">
<router-view/>
</div>
</template>
<script>
export default {
name: 'App'
}
</script>
<style>
@import './style/font';
</style>
(2)font.css
把需要⾃定义放在字体列表的字体放在这个css中,选择器如下。data-value后的值是要拼在.ql-font-后⾯的,需要保持⼀致。[data-value=a]    ql-font-a
content指的是字体列表中的选项
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=SimSun]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=SimSun]::before {
content: "宋体";
font-family: "SimSun";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=SimHei]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=SimHei]::before {
content: "⿊体";
font-family: "SimHei";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=Microsoft-YaHei]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=Microsoft-YaHei]::before {
content: "微软雅⿊";
font-family: "Microsoft YaHei";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=KaiTi]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=KaiTi]::before {
content: "楷体";
font-family: "KaiTi";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=FangSong]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=FangSong]::before {
content: "仿宋";
font-family: "FangSong";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=Arial]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=Arial]::before {
content: "Arial";
font-family: "Arial";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=Times-New-Roman]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=Times-New-Roman]::before {
content: "Times New Roman";
font-family: "Times New Roman";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=sans-serif]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=sans-serif]::before {
content: "sans-serif";
font-family: "sans-serif";
}
.ql-font-SimSun {
font-family: "SimSun";
}
.ql-font-SimHei {
font-family: "SimHei";
}
.ql-font-Microsoft-YaHei {
font-family: "Microsoft YaHei";
}
.ql-font-KaiTi {
font-family: "KaiTi";
}
.ql-font-FangSong {
font-family: "FangSong";
}
.ql-font-Arial {
font-family: "Arial";
}
.ql-font-Times-New-Roman {
font-family: "Times New Roman";
}
.ql-font-sans-serif {
font-family: "sans-serif";
}
(3).vue⽂件中
<script>
import { quillEditor } from 'vue-quill-editor'
import * as Quill from 'quill' //引⼊编辑器
//quill编辑器的字体
var fonts = ['SimSun', 'SimHei','Microsoft-YaHei','KaiTi','FangSong','Arial','Times-New-Roman','sans-serif'];
var Font = Quill.import('formats/font');
Font.whitelist = fonts; //将字体加⼊到⽩名单
export default {
data:function(){
return{
content:'',
editorOption:{
modules:{
toolbar:[
['bold', 'italic', 'underline', 'strike'],
['blockquote', 'code-block'],
[{ 'header': 1 }, { 'header': 2 }],
[{ 'list': 'ordered'}, { 'list': 'bullet' }],
[{ 'script': 'sub'}, { 'script': 'super' }],
[{ 'indent': '-1'}, { 'indent': '+1' }],
[{ 'direction': 'rtl' }],
[{ 'size': ['small', false, 'large', 'huge'] }],
[{ 'header': [1, 2, 3, 4, 5, 6, false] }],
[{ 'color': [] }, { 'background': [] }],
[{ 'font': fonts }],    //把上⾯定义的字体数组放进来              [{ 'align': [] }],
['clean'],
['image','video']
]
},
theme:'snow'
}
}
}
}
</script>
效果图如下:
三、图⽚拖拽上传ImgeDrop
<script>
import { quillEditor } from 'vue-quill-editor'
import * as Quill from 'quill' //引⼊编辑器
//quill图⽚可拖拽上传
import { ImageDrop } from 'quill-image-drop-module';
export default {
data:function(){
return{
editorOption:{
modules:{
imageDrop:true,
},
theme:'snow'
}
}
}
}
</script>
四、图⽚调整⼤⼩ImageResize
<script>
import { quillEditor } from 'vue-quill-editor'
import * as Quill from 'quill' //引⼊编辑器
//quill图⽚可拖拽改变⼤⼩
import ImageResize from 'quill-image-resize-module'
export default {
data:function(){
return{
editorOption:{
modules:{
imageResize: {}
},
theme:'snow'
}
}
}
}
</script>
效果图如下:可以调整图⽚的对齐⽅式,并显⽰图⽚的⼤⼩
Quill使⽤基本如上。安装可参考:
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。