[data:image/s3,"s3://crabby-images/e8e63/e8e633ad75707b88043de554dde140565030d70b" alt="GitHub stars"](https://github.com/surmon-china/vue-quill-editor/stargazers)
[data:image/s3,"s3://crabby-images/1f489/1f4894a73ba703f4b4873f7f7a1414bc91bda69d" alt="Build Status"](https://travis-ci.org/surmon-china/vue-quill-editor)
[data:image/s3,"s3://crabby-images/71723/71723e2a66187c1436b1c5933a79787f6740b536" alt="GitHub issues"](https://github.com/surmon-china/vue-quill-editor/issues)
[data:image/s3,"s3://crabby-images/ccf1c/ccf1c73e5074527d8f6811eedb9a94c2ba52a1ce" alt="GitHub forks"](https://github.com/surmon-china/vue-quill-editor/network)
[data:image/s3,"s3://crabby-images/e6570/e65703f7e279c9c1079371cf05ef792b704d681d" alt="GitHub last commit"](https://github.com/surmon-china/vue-quill-editor)
[data:image/s3,"s3://crabby-images/589bd/589bd9fdddf6e4cc99cfca5cbc33a1f807519d9e" alt="license"](https://github.com/surmon-china/vue-quill-editor)
[data:image/s3,"s3://crabby-images/6c68e/6c68eeba8d98141f62d7d36c7582c0263dba0d0d" alt="Twitter"](https://twitter.com/intent/tweet?url=https://github.com/surmon-china/vue-quill-editor)
[data:image/s3,"s3://crabby-images/2d01e/2d01eeaddfe33a44fff59f00b12b0b5fe18ce387" alt=""](https://juejin.im/entry/5852b6fc61ff4b006c89b49d/detail)
[data:image/s3,"s3://crabby-images/a36dc/a36dcdcf42a71d3924e19bdf268af447edd43a83" alt="NPM"](https://nodei.co/npm/vue-quill-editor/)
[data:image/s3,"s3://crabby-images/f73ce/f73cef2c8290170703a1c96bb74d13d1defd5397" alt="NPM"](https://nodei.co/npm/vue-quill-editor/)
# Vue-Quill-Editor
🍡Quill editor component for Vue, support SPA and SSR.
基于 Quill、适用于 Vue 的富文本编辑器,支持服务端渲染和单页应用。
## Example
[Demo Page](https://surmon-china.github.io/vue-quill-editor/)
[CDN Example](https://jsfiddle.net/tng9r8j3/)
[Nuxt.js/SSR example code](https://github.com/surmon-china/vue-quill-editor/blob/master/examples/nuxt-ssr-example)
#### Projects Using Vue-Quill-Editor
[Tamiat CMS](https://github.com/tamiat/tamiat/)
## Install
#### CDN
``` html
```
#### NPM
``` bash
npm install vue-quill-editor --save
```
### Mount
#### mount with global
``` javascript
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, /* { default global options } */)
```
#### mount with component
```javascript
// require styles
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
}
}
```
#### mount with ssr
```javascript
// if used in nuxt.js/ssr, you should keep require it only in browser build environment
if (process.browser) {
const VueQuillEditor = require('vue-quill-editor/dist/ssr')
Vue.use(VueQuillEditor, /* { default global options } */)
}
```
#### register quill module
```javascript
// register quill modules, you need to introduce and register before the vue program is instantiated
import Quill from 'quill'
import yourQuillModule from '../yourModulePath/yourQuillModule.js'
Quill.register('modules/yourQuillModule', yourQuillModule)
```
### Difference(使用方法的区别)
**SSR and the only difference in the use of the SPA:**
- SPA worked by the `component`, find quill instance by `ref attribute`.
- SSR worked by the `directive`, find quill instance by `directive arg`.
- Other configurations, events are the same.
### SSR
``` vue
```
### SPA
``` vue
```
## Modules
- [quill-image-extend-module](https://github.com/NextBoy/quill-image-extend-module)
- [quill-image-resize-module](https://github.com/kensnyder/quill-image-resize-module)
- [quill-image-drop-module](https://github.com/kensnyder/quill-image-drop-module)
- [quilljs-table](https://github.com/dost/quilljs-table)
- [more modules...](https://github.com/search?o=desc&q=quill+module&s=stars&type=Repositories&utf8=%E2%9C%93)
## Issues
- [Add attributes from toolbar options](https://github.com/quilljs/quill/issues/1084)
- [Option to insert an image from a URL](https://github.com/quilljs/quill/issues/893)
- [How vue-quill-editor combine with the syntax highlighter module of highlight.js](https://github.com/surmon-china/vue-quill-editor/issues/39)
- [配合 element-ui 实现上传图片/视频到七牛 demo](https://github.com/surmon-china/vue-quill-editor/issues/102)
- [How to fix “Can’t find variable: Quill”, “Quill is undefined”, “window.Quill is undefined” errors when trying to use Quill modules that use Webpack in Nuxt/SSR](https://github.com/surmon-china/vue-quill-editor/issues/171#issuecomment-370253411)
## Quill documents
[Api docs](https://quilljs.com/docs/quickstart/)
## Author
[Surmon](https://surmon.me)