来自 Web前端 2020-04-22 18:38 的文章
当前位置: 澳门三合彩票 > Web前端 > 正文

当大家供给为输入的文本加多格式时,小编在已

时间: 2019-12-21阅读: 72标签: 富文本quill 定制富文本编辑器

本文为大家记录了vue中安装使用Quill富文本编辑器的具体方法,供大家参考,具体内容如下

项目中原本使用的富文本编辑器是 wangEditor,这是一个很轻量、简洁编辑器

很多时候textarea并不能满足我们对文本输入的需求,当我们需要为输入的文本添加格式时,我们需要使用像 quill 这样的富文本编辑器来完成富文本的输入。

1、安装依赖

但是公司的业务升级,想要一个功能更全面的编辑器,我找了好久,目前常见的编辑器有这些:

本文将会详细的讲解如何使用 quill 定制一个自己的富文本编辑器。

npm install vue-quill-editor --save

UEditor:百度前端的开源项目,功能强大,基于 jQuery,但已经没有再维护,而且限定了后端代码,修改起来比较费劲

这里面定制了两个特殊的功能(添加卡片、添加图片墙),感兴趣的同学可以先看一下实现后的效果:富文本编辑器

注:我在已有的vue项目中(含有已安装的依赖,即node_modules文件夹)直接进行安装并不成功,报错,没有截图,但是我没记错的话是显示"项目名node_modulescliuinode_moduleswordwrap"这个没有。所以我把项目下的node_modules文件删除,然后直接安装quill依赖(执行npm install vue-quill-editor --save)。然后npm run dev 运行项目,不影响之前vue项目的使用和运行,quill的富文本编辑器也可以用了。

bootstrap-wysiwyg:微型,易用,小而美,只是 Bootstrap + jQuery...

接下来将会讲解如何在 quill 的基础上实现定制化的富文本编辑器。

2、使用

kindEditor:功能强大,代码简洁,需要配置后台,而且好久没见更新了

quill 简介

在“项目名澳门三合彩票,srcmain.js”引入

wangEditor:轻量、简洁、易用,但是升级到 3.x 之后,不便于定制化开发。不过作者很勤奋,广义上和我是一家人,打个call

一个好的富文本编辑器的标志就是它能够支持多少种格式,而 quill 支持无限种类的格式。你可以在 quill 上定制任意种类的文本。并且,如果你不想自定义个任何功能,那么 quill 也是极易上手的

import Vue from 'vue'import VueQuillEditor from 'vue-quill-editor'

//一定要引入这三个css,不然文本编辑器会出现不规则黑白几何图形//这三个css可以在main.js中引入,也可以在具体使用的.vue文件中引入import 'quill/dist/quill.core.css'import 'quill/dist/quill.snow.css'import 'quill/dist/quill.bubble.css' Vue.use

quill:本身功能不多,不过可以自行扩展,api 也很好懂,如果能看懂英文的话...

var quill = new Quill('#editor', { modules: { toolbar: true }, theme: 'snow'})

在具体vue文件中引用

summernote:没深入研究,UI挺漂亮,也是一款小而美的编辑器,可是我需要大的

如何在 Quill 上定制功能

import { quillEditor } from 'vue-quill-editor' export default { data:function(){ return{ content:'', editorOption:{} } }, methods:{ onEditorBlur{//失去焦点事件 }, onEditorFocus{//获得焦点事件 }, onEditorChange{//编辑器文本发生变化 //this.content可以实时获取到当前编辑器内的文本内容 console.log; } }} 

在有这么参考的情况下,我最终还是选择了 tinymce 这个不搭梯子连官网都打不开的编辑器,主要因为两点:

quill 提供了非常细粒度、定义良好的 API,我们可以在此基础之上定制化开发自己的富文本编辑器。(环境为 Vue + iview ,使用 iview 进行辅助样式开发)

v-model 可以不使用,并不是Quill编辑器自带的,是我项目中使用自己加的。

  1. GitHub 上星星很多,功能也齐全;

  2. 唯一一个从 word 粘贴过来还能保持绝大部分格式的编辑器;

  3. 不需要找后端人员扫码改接口,前后端分离;

首先我们从最简单的 demo 入手

这样引入后可以得到一个这样的编辑器。

一、资源下载

template div /div/templatescriptimport Quill from "quill";export default { mounted() { const quill = new Quill("#editor", { theme: "snow", placeholder: "请在此开始编辑..." }); }};/script

如果需要改变文本域部分的高度,如下:

tinymce 官方为 vue 项目提供了一个组件 tinymce-vue

这是一个默认参数条件下的一个富文本编辑器,我们首先对 Toolbar 进行替换,Toolbar 是 modules 的一部分。

 .quill-editor { height: 350px; }
npm install @tinymce/tinymce-vue -S

我们需要在新建 quill 实例的时候覆盖原来的 toolbar,并使用的自己的 toolbar 元素。

Quill的自定义工具栏、字体等,请点击:vue中Quill富文本编辑器的使用

在 vscode、webstorm 的终端运行这段代码可能会报错,最好使用操作系统自带的命令行工具

template div  div  Tooltip content="加粗" placement="bottom" button /button /Tooltip Tooltip content="倾斜" placement="bottom" button /button /Tooltip Tooltip content="下划线" placement="bottom" button /button /Tooltip Tooltip content="删除线" placement="bottom" button /button /Tooltip /div div /div /div/templatescriptimport Quill from "quill";export default { mounted() { const quill = new Quill("#editor", { theme: "snow", modules: { toolbar: "#toolbar" }, placeholder: "请在此开始编辑..." }); }};/scriptstyle lang="less" scoped/style

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

如果有购买 tinymce 的服务,可以参考 tinymce-vue 的说明,通过 api-key 直接使用 tinymce

本文由澳门三合彩票发布于Web前端,转载请注明出处:当大家供给为输入的文本加多格式时,小编在已

关键词: