VueQuill 富文本编辑器技术文档快速上手

VueQuill 富文本编辑器技术文档

    • [1. 安装 VueQuill](#1. 安装 VueQuill)
    • [2. 配置 VueQuill](#2. 配置 VueQuill)
    • [3. 在组件中使用 VueQuill](#3. 在组件中使用 VueQuill)
    • [4. 配置选项](#4. 配置选项)
    • [5. 事件处理](#5. 事件处理)
    • [6. 数据格式](#6. 数据格式)
    • [7. 自定义工具栏](#7. 自定义工具栏)
    • [8. 示例项目结构](#8. 示例项目结构)
    • [9. 常见问题](#9. 常见问题)

在此之前,我讲解过关于VueQuill是什么的文章点击查看
什么是 VueQuill(前端的富文本编辑器)?

1. 安装 VueQuill

要在你的 Vue 项目中使用 VueQuill,你需要首先安装 vue-quill-editorquill 包。

bash 复制代码
npm install vue-quill-editor quill --save

2. 配置 VueQuill

在你的 Vue 项目中,配置 VueQuill 编辑器。你需要在你的主 JavaScript 文件(通常是 main.js)中引入并注册 VueQuill。

javascript 复制代码
// main.js

import Vue from 'vue'
import App from './App.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)

new Vue({
  render: h => h(App)
}).$mount('#app')

3. 在组件中使用 VueQuill

在你的 Vue 组件中使用 VueQuill 编辑器。你可以通过引入 quill-editor 组件来使用它。

vue 复制代码
<template>
  <div id="app">
    <quill-editor
      v-model="content"
      :options="editorOptions"
      @blur="onEditorBlur($event)"
      @focus="onEditorFocus($event)"
      @change="onEditorChange($event)"
    />
  </div>
</template>

<script>
export default {
  data() {
    return {
      content: '',
      editorOptions: {
        theme: 'snow'
      }
    }
  },
  methods: {
    onEditorBlur(editor) {
      console.log('editor blur!', editor)
    },
    onEditorFocus(editor) {
      console.log('editor focus!', editor)
    },
    onEditorChange({ editor, html, text }) {
      console.log('editor change!', editor, html, text)
    }
  }
}
</script>

<style>
@import "~quill/dist/quill.snow.css";
</style>

4. 配置选项

你可以通过 editorOptions 来配置 Quill 编辑器的选项。以下是一些常见的配置:

javascript 复制代码
export default {
  data() {
    return {
      content: '',
      editorOptions: {
        // 主题配置
        theme: 'snow',
        // 工具栏配置
        modules: {
          toolbar: [
            [{ 'header': [1, 2, false] }],
            ['bold', 'italic', 'underline'],
            ['image', 'code-block']
          ]
        }
      }
    }
  }
}

5. 事件处理

VueQuill 支持多种事件处理,包括 @blur@focus@change。你可以在方法中处理这些事件:

javascript 复制代码
methods: {
  onEditorBlur(editor) {
    console.log('editor blur!', editor)
  },
  onEditorFocus(editor) {
    console.log('editor focus!', editor)
  },
  onEditorChange({ editor, html, text }) {
    console.log('editor change!', editor, html, text)
  }
}

6. 数据格式

VueQuill 编辑器的内容可以以 HTML 或 Delta 格式存储。你可以通过 v-model 绑定数据,并在处理数据时根据需要进行转换。

javascript 复制代码
data() {
  return {
    content: ''
  }
},
methods: {
  saveContent() {
    // 存储 HTML 格式
    const htmlContent = this.content

    // 存储 Delta 格式
    const deltaContent = this.$refs.quillEditor.quill.getContents()

    console.log('HTML Content:', htmlContent)
    console.log('Delta Content:', deltaContent)
  }
}

7. 自定义工具栏

你可以自定义 Quill 编辑器的工具栏,添加或删除按钮和功能。

javascript 复制代码
editorOptions: {
  modules: {
    toolbar: [
      [{ 'header': '1' }, { 'header': '2' }, { 'font': [] }],
      [{ 'list': 'ordered'}, { 'list': 'bullet' }],
      ['bold', 'italic', 'underline'],
      ['image', 'code-block']
    ]
  }
}

8. 示例项目结构

复制代码
my-vue-quill-project
├── node_modules
├── public
│   ├── index.html
├── src
│   ├── assets
│   ├── components
│   │   └── MyEditor.vue
│   ├── App.vue
│   └── main.js
├── .gitignore
├── package.json
└── README.md

9. 常见问题

如何添加图片上传功能?

你可以自定义 Quill 工具栏并实现图片上传功能。具体实现可以参考 Quill 文档。

如何自定义编辑器主题?

你可以通过引入不同的 Quill 样式文件并在 editorOptions 中设置 theme 来自定义主题。


相关推荐
hpoenixf5 小时前
2026 年前端面试问什么
前端·面试
还是大剑师兰特6 小时前
Vue3 中的 defineExpose 完全指南
前端·javascript·vue.js
泯泷6 小时前
阶段一:从 0 看懂 JSVMP 架构,先在脑子里搭出一台最小 JSVM
前端·javascript·架构
mengchanmian7 小时前
前端node常用配置
前端
华洛7 小时前
利好打工人,openclaw不是企业提效工具,而是个人助理
前端·javascript·产品经理
xkxnq7 小时前
第六阶段:Vue生态高级整合与优化(第93天)Element Plus进阶:自定义主题(变量覆盖)+ 全局配置与组件按需加载优化
前端·javascript·vue.js
A黄俊辉A8 小时前
vue css中 :global的使用
前端·javascript·vue.js
小码哥_常8 小时前
被EdgeToEdge适配折磨疯了,谁懂!
前端
小码哥_常8 小时前
从Groovy到KTS:Android Gradle脚本的华丽转身
前端
灵感__idea8 小时前
Hello 算法:复杂问题的应对策略
前端·javascript·算法