vue2 之 Vue-Quill-Editor富文本编辑器

一、安装

1. 下载

javascript 复制代码
npm i vue-quill-editor

2. 配置

页面配置

javascript 复制代码
<script>
import 'quill/dist/quill.core.css';
import 'quill/dist/quill.snow.css';
import 'quill/dist/quill.bubble.css';
import { quillEditor } from 'vue-quill-editor';

export default {
  components: { quillEditor }
}
</script>

全局配置

javascript 复制代码
import Vue from 'vue'
import VueQuillEditor from 'vue-quill-editor'
 
// 引入样式
import 'quill/dist/quill.core.css'
import 'quill/dist/quill.snow.css'
import 'quill/dist/quill.bubble.css'
 
Vue.use(VueQuillEditor)

二、使用

1. 效果

2. 代码

javascript 复制代码
<template>
  <div class="view">
    <quill-editor
      class="ql-editor"
      v-model="content"
      ref="myQuillEditor"
      :options="editorOption"
      @blur="onEditorBlur($event)"
      @focus="onEditorFocus($event)"
      @change="onEditorChange($event)"
    />
    <div class="limit-box">{{ currentLnegth }}/{{ limitLength }}</div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      content: ``, //双向数据绑定数据
      // 富文本编辑器配置
      editorOption: {
        placeholder: '请输入正文',
        modules: {
          toolbar: [
            ['bold', 'italic', 'underline', 'strike'], // 加粗 斜体 下划线 删除线
            ['blockquote', 'code-block'], // 引用  代码块
            [{ header: 1 }, { header: 2 }], // 1、2 级标题 标题,键值对的形式;1、2表示字体大小
            [{ list: 'ordered' }, { list: 'bullet' }], // 有序、无序列表
            [{ script: 'sub' }, { script: 'super' }], // 上标/下标
            [{ indent: '-1' }, { indent: '+1' }], // 缩进
            // [{ direction: 'rtl' }], // 文本方向
            [{ size: ['12px', false, '16px', '18px', '20px', '30px'] }], // 字体大小
            [{ header: [1, 2, 3, 4, 5, 6, false] }], // 标题
            [{ color: [] }, { background: [] }], // 字体颜色、字体背景颜色
            [
              { font: [false, 'SimSun', 'SimHei', 'Microsoft-YaHei', 'KaiTi', 'FangSong', 'Arial'] }
            ], // 字体种类
            [{ align: [] }], // 对齐方式
            ['clean'], // 清除文本格式
            ['link', 'image', 'video'] // 链接、图片、视频
          ]
        }
      },
      currentLnegth: 0,
      limitLength: 500
    };
  },
  methods: {
    // 失去焦点事件
    onEditorBlur(quill) {
      console.log('editor blur!', quill);
    },
    // 获得焦点事件
    onEditorFocus(quill) {
      console.log('editor focus!', quill);
    },
    // 准备富文本编辑器
    onEditorReady(quill) {
      console.log('editor ready!', quill);
    },
    // 内容改变事件
    onEditorChange({ quill, html, text }) {
      console.log('editor change!', quill, html, text);

      quill.deleteText(this.limitLength, 1);
      this.currentLnegth = quill.getLength() - 1;
    }
  }
};
</script>

<style>
.quill-editor /deep/ .ql-container {
  min-height: 230px;
}

.ql-container {
  min-height: 230px;
}
</style>
相关推荐
Setsuna_F_Seiei9 分钟前
CocosCreator 游戏开发 - 利用 AssetsBundle 技术对小游戏包体积进行优化
前端·cocos creator·游戏开发
黄毛火烧雪下19 分钟前
高效的项目构建和优化之前端构建工具
前端
90后的晨仔1 小时前
在 macOS 上轻松获取 GIF 图片总时长:多种实用方法详解
前端
技术钱1 小时前
vue3前端解析excel文件
前端·vue.js·excel
mapbar_front1 小时前
顺利通过试用期:避开三大陷阱,掌握三个关键点
前端·面试
韩立学长1 小时前
【开题答辩实录分享】以《智慧校园勤工俭学信息管理系统的设计与实现》为例进行答辩实录分享
vue.js·spring boot·微信小程序
掘金安东尼1 小时前
Transformers.js:让大模型跑进浏览器
开发语言·javascript·ecmascript
why技术2 小时前
1K+Star的开源项目能给一个在校大学生带来什么?
前端·人工智能·后端
@PHARAOH2 小时前
HOW - localstorage 超时管理方案
前端·javascript·vue.js
im_AMBER2 小时前
React 05
开发语言·前端·javascript·笔记·学习·react.js·前端框架