element vue-quill-editor 富文本编辑器 安装使用

1、安装:npm install vue-quill-editor --save

2、页面导入:

import { quillEditor } from 'vue-quill-editor'

import 'quill/dist/quill.core.css'
import 'quill/dist/quill.snow.css'
import 'quill/dist/quill.bubble.css'

components: {
quillEditor
},

 页面:

<quill-editor style="height:280px;line-height:24px"
                v-model="content"
                ref="myQuillEditor"
                :options="editorOption"
                @blur="onEditorBlur($event)" @focus="onEditorFocus($event)"
                @change="onEditorChange($event)">
                </quill-editor>

 ------------------------------------------------------------

工具栏汉化:

样式模块重写

<style>
p {
  margin: 10px;
}

.edit_container,
.quill-editor {
  height: 300px;
}

.ql-snow .ql-picker.ql-size .ql-picker-label::before,
.ql-snow .ql-picker.ql-size .ql-picker-item::before {
  content: "14px";
}

.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="small"]::before,
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="small"]::before {
  content: "10px";
}
.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="large"]::before,
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="large"]::before {
  content: "18px";
}
.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="huge"]::before,
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="huge"]::before {
  content: "32px";
}

.ql-snow .ql-picker.ql-header .ql-picker-label::before,
.ql-snow .ql-picker.ql-header .ql-picker-item::before {
  content: "文本";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before {
  content: "标题1";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before {
  content: "标题2";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before {
  content: "标题3";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before {
  content: "标题4";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before {
  content: "标题5";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]::before {
  content: "标题6";
}

.ql-snow .ql-picker.ql-font .ql-picker-label::before,
.ql-snow .ql-picker.ql-font .ql-picker-item::before {
  content: "标准字体";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value="serif"]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value="serif"]::before {
  content: "衬线字体";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value="monospace"]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value="monospace"]::before {
  content: "等宽字体";
}
</style>

工具栏加入悬浮提示

const titleConfig=[
            {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:'两端对齐'}
        ];


mounted(){
autotip:{
document.getElementsByClassName('ql-editor')[0].dataset.placeholder=''
for(let item of titleConfig){
let tip = document.querySelector('.quill-editor '+ item.Choice)
if (!tip) continue
tip.setAttribute('title',item.title)
}
}
},

 

-----------------------------------------------------------------------------

实现效果

整体代码

<template>
  <div class='page'>
    <!--form区域-->
    <div class="form-area">
      <el-form ref="form" label-width="130px" label-suffix=":" :model="form" :rules="rules">
        <!---------------------------------新增详情----------------------------------->
        <div class="form-content">
           <el-row :gutter="0" style="height:360px;">
            <el-col :span="24">
              <el-form-item label="工作总结" prop="summary">
              <quill-editor style="height:280px;line-height:24px"
                v-model="content"
                ref="myQuillEditor"
                :options="editorOption"
                @blur="onEditorBlur($event)" @focus="onEditorFocus($event)"
                @change="onEditorChange($event)">
                </quill-editor>
              </el-form-item>
            </el-col>
          </el-row>
        </div>
      </el-form>
    </div>
  </div>
</template>

<script>
import { quillEditor } from 'vue-quill-editor'
import 'quill/dist/quill.core.css'
import 'quill/dist/quill.snow.css'
import 'quill/dist/quill.bubble.css'
const titleConfig=[
            {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:'两端对齐'}
        ];

export default {
  name: 'HrBecomeRegularApply',
  data(){
    return {
      content:null,
      editorOption:{
        theme: 'snow', 
        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': [] }],
            [{ 'align': [] }],
            ['clean'],
            ['link', 'image', 'video']
          ],
      },
      }}
  },
  components: {
    quillEditor
  },
  mounted(){
    autotip:{
            document.getElementsByClassName('ql-editor')[0].dataset.placeholder=''
            for(let item of titleConfig){
                let tip = document.querySelector('.quill-editor '+ item.Choice)
                if (!tip) continue
                tip.setAttribute('title',item.title)
            }
          }
  },
  created(){
  },
  methods: {
  }
}
</script>
<style lang='scss' scoped>

.btnupload{
  background: #fff;
  color:#2E8BF0;
  border: 1px dashed #666666;
}
.el-upload__tip{
  font-weight: 400;
  color: #999999;
  line-height: 18px;
  margin-left:10px;
}
</style>
<style>
p {
  margin: 10px;
}

.edit_container,
.quill-editor {
  height: 300px;
}

.ql-snow .ql-picker.ql-size .ql-picker-label::before,
.ql-snow .ql-picker.ql-size .ql-picker-item::before {
  content: "14px";
}

.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="small"]::before,
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="small"]::before {
  content: "10px";
}
.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="large"]::before,
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="large"]::before {
  content: "18px";
}
.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="huge"]::before,
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="huge"]::before {
  content: "32px";
}

.ql-snow .ql-picker.ql-header .ql-picker-label::before,
.ql-snow .ql-picker.ql-header .ql-picker-item::before {
  content: "文本";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before {
  content: "标题1";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before {
  content: "标题2";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before {
  content: "标题3";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before {
  content: "标题4";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before {
  content: "标题5";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]::before {
  content: "标题6";
}

.ql-snow .ql-picker.ql-font .ql-picker-label::before,
.ql-snow .ql-picker.ql-font .ql-picker-item::before {
  content: "标准字体";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value="serif"]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value="serif"]::before {
  content: "衬线字体";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value="monospace"]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value="monospace"]::before {
  content: "等宽字体";
}
</style>
原文地址:https://www.cnblogs.com/aoshuang/p/14841194.html