DevUI 是一款面向企业中后台产品的开源前端解决方案,它倡导沉浸
、灵活
、至简
的设计价值观,提倡设计者为真实的需求服务,为多数人的设计,拒绝哗众取宠、取悦眼球的设计。若是你正在开发 ToB
的工具类产品
,DevUI 将是一个很不错的选择!css
如下文章和本文相关,也许你也会喜欢:前端
《Quill富文本编辑器的实践》github
引言
以前在HWEB大前端技术分享会上给你们分享过 Quill 的一些实践,不过因为时间关系只讲了个大概,后续打算深刻浅出地对 Quill 作一个详细的介绍。编辑器
这个系列打算从实践的角度去讲 Quill 富文本编辑器,先从 Quill 的基本使用开始吧!ide
极简方式使用 Quill
快速开始三部曲:模块化
- 安装
- 引入
- 使用
// 安装 npm i quill
<div id="editor"></div>
// 引入 import Quill from 'quill'; // 使用 const quill = new Quill('#editor');
虽然咱们已经初始化了 Quill 实例,可是在页面中却什么也看不到。
虽然看上去什么也没有,可是咱们点击空白处,会发现有一个光标,而且能够输入内容,并给内容增长格式(因为没有工具栏,只能经过 Quill 快捷键Ctrl+B
增长格式),如下是动画效果:
虽然只是一个极简版的富文本编辑器,不过加上边框和按钮,就是一个基础版的掘金评论框(还差插入表情和图片)😜
这是使用 Quill 最简单的方式。
加一些配置选项吧
配置编辑器容器元素 container
Quill 类一共有两个参数,第一个参数是必选的编辑器容器元素container
,能够是一个CSS选择器,好比前面的#editor
,也能够是一个DOM元素,好比:
const container = document.getElementById('editor'); // const container = document.querySelector('#editor'); // const container = $('#editor').get(0); const quill = new Quill(container);
若是容器里面已经有一些 HTML 元素,那么初始化 Quill 的时候,那些元素也会渲染出来,好比:
<div id="editor"> <p>DevUI:面向企业中后台的前端开源解决方案</p> <h2>宗旨与法则</h2> <p>规范的组件化的目的不是为了限制创造,而是为了创造者更肯定、科学、高效。全部行为决策的价值归依是产品业务。产品业务永远比组件化自己更重要,业务第一。</p> <p>规范不是绝对、教条、冷漠、强制的,实际工做中总会有新增需求、存优化空间、情感化设计需求超出通常通用规范。保持克制的同时,容许基于强烈业务需求的规范突破;以后若是有足够的理由迭代出组件,那么就进行组件深化。</p> <h2>设计语言</h2> <p>DevUI的价值观奠基了 DevCloud品牌的基础。它是 DevCloud 的设计师们思考、工做的产物,反映了 DevCloud 的产品文化、设计理念和对客户的承诺。DevUI的这些价值观贯穿于全部产品和面向客户的沟通和内容中。同时,它是 DevUI 设计原则的源头,为具体的设计方法提供启发和指引。</p> <p>DevUI倡导<code>沉浸</code>、<code>灵活</code>、<code>致简</code>的设计价值观,提倡设计者为真实的需求服务,为多数人的设计,拒绝哗众取宠、取悦眼球的设计。</p> <h2>致简</h2> <p>DevUI坚持以用户为中心去进行设计,注重直观可达性,把服务示例化以帮助用户快速融入到使用中去。同时, DevUI提供大量的快捷键,简化使用的流程、提升操做效率。</p> <h2>沉浸</h2> <p>DevUI的沉浸式体验包括人的感官体验和认知体验,当用户的我的技能与面对的挑战互相匹配,而且长时间处在稳定状态时,用户达到心流状态而且不易被外界因素所干扰。</p> <p>在产品设计中,DevUI专一在下降用户在完成任务目标时的认知阻力中。为此,DevUI同时提供多种不一样的切换页面的途径,包括面包屑、快捷键、按钮和连接等,方便用户随时快速、连续地切换页面,到达本身所需的页面,使用户处于流畅的体验中,减轻寻找信息的焦虑感。</p> <h2>灵活</h2> <p>DevUI提供超过60个独立原子级组件,能够自由组合,像搭积木同样,用小组件搭建出符合自身产品须要的分子级组件,进而搭建出本身的业务系统。</p> </div>
渲染出来的编辑器效果:
配置选项 options
第二个参数是可选的配置选项options
,options是一个JSON对象,好比咱们想给咱们的编辑器增长一个主题,使它再也不那么单调。
const quill = new Quill('#editor', { theme: 'snow' });
另外须要引入该主题对应的样式:
@import 'quill/dist/quill.snow.css';
这时咱们看到编辑器已经有一个工具栏。
而且能够经过工具栏对编辑器的内容进行操做,好比给DevUI
增长一个超连接:
除了snow
主题,Quill 还内置了一个bubble
气泡主题,配置方式和snow
主题同样:
- 引入主题样式
- 在options里配置主题
// 引入bubble主题样式 @import 'quill/dist/quill.bubble.css';
const quill = new Quill('#editor', { theme: 'bubble' // 配置 bubble 主题 });
效果以下:
bubble主题没有显性的工具栏,它会在你选中编辑器中的文本时,在选中文本的下方显示一个气泡工具栏,从而对文本进行格式化操做,好比给选中的段落增长引用格式:
更多配置选项
Quill 不只仅能够配置主题,options一共支持8个配置选项:
- bounds 编辑器内浮框的边界
- debug debug级别
- formats 格式白名单
- modules 模块
- placeholder 占位文本
- readOnly 只读模式
- scrollingContainer 滚动容器
- theme 主题
formats 格式白名单
这个配置项很是有用,好比刚刚提到的掘金评论框,咱们发现评论框里只能插入纯文本,其余格式都不容许,即便时粘贴进来的格式化文本也会变成纯文本。
在 Quill 里很容易实现,只须要配置formats
为空数组便可。
const quill = new Quill('#editor', { theme: 'snow', formats: [] });
注意这里的formats
格式白名单,控制的是内容实际的格式,和设置格式的渠道无关,好比formats
设置为空,那么不管是:
- 经过工具栏设置格式
- 仍是经过快捷键(好比
Ctrl+B
)设置格式 - 抑或是粘贴带格式的文本 都是没法设置格式的。
若是咱们想保留一部分格式,好比只保留粗体
和列表
两种格式:
const quill = new Quill('#editor', { theme: 'snow', formats: [ 'bold', 'list' ] });
Quill 一共支持11
种行内格式:
- background
- bold
- color
- font
- code
- italic
- link
- size
- strike
- script
- underline
7
种块级格式:
- blockquote
- header
- indent
- list
- align
- direction
- code-block
3
种嵌入格式:
- formula
- image
- video
不配置formats
选项,会默认支持全部的21
种格式。
placeholder 占位文本
咱们发现掘金的评论框在没有输入内容时,会有一个输入评论...
的占位文本。
这能够很容易地经过配置placeholder
选项实现。
const quill = new Quill('#editor', { formats: [], placeholder: '输入评论...', });
readOnly 只读模式
经过配置readOnly
能够实现:
初始状态编辑器是阅读态,不能够编辑,能够经过点击
编辑
按钮让编辑器变成编辑态。
因为掘金的评论框不支持编辑,就不拿它举例子。
以 DevCloud 看板项目的评论框为例,初始状态下评论是不可编辑的,点击编辑
按钮,变成可编辑状态,而且显示工具栏、保存按钮等元素,点击保存按钮,新增的内容被保存,编辑器变成只读态。
modules 模块配置
这个配置项放在最后并不表明它不重要,偏偏相反,这是 Quill 中最重量级
也是最经常使用
的配置。
在以前的文章中,给你们介绍过 Quill 的模块化机制,这个配置项就是用来配置 Quill 的模块的。
在Quill的模块化机制一文中,咱们提到
Quill 一共有6个内置模块:
- Clipboard 粘贴版
- History 操做历史
- Keyboard 键盘事件
- Syntax 语法高亮
- Toolbar 工具栏
- Uploader 文件上传
每一个模块的用途详见Quill内置模块章节。
modules
选项能够用来配置这些模块。
配置 toolbar 模块
Quill 默认只在工具栏中显示一部分格式化按钮,里面没有插入图片的按钮,咱们能够经过配置toolbar
模块来增长。
const quill = new Quill('#editor', { theme: 'snow', modules: { toolbar: [ // 默认的 [{ header: [1, 2, 3, false] }], ['bold', 'italic', 'underline', 'link'], [{ list: 'ordered'}, { list: 'bullet' }], ['clean'], // 新增的 ['image'] ] } });
若是想作一个掘金这样的富文本编辑器,也很是简单。
掘金的富文本编辑器主要包含如下工具栏按钮:
- 加粗
- 斜体
- 下划线
- 一级/二级标题
- 引用
- 代码块
- 行内代码
- 无序列表
- 有序列表
- 超连接
- 插入图片
使用 Quill 实现,须要这样配置toolbar
模块。
const quill = new Quill('#editor', { theme: 'snow', modules: { toolbar: [ 'bold', 'italic', 'underline', { header: 1 }, { header: 2 }, 'blockquote', 'code-block', 'code', 'link', { list: 'ordered'}, { list: 'bullet' }, 'image', ] } });
稍微修改下样式,就能作出一个和掘金富文本编辑器差很少的富文本编辑器啦,效果以下:
如下是和掘金实际的富文本编辑器的对比图:
对比以上效果对比图,除了工具栏的 icon 使用的是掘金 Markdown 编辑器的 icon 以外,其余几乎是同样的。
配置 keyboard 模块
除了工具栏模块,咱们还能够配置别的模块,好比快捷键模块keyboard
,keyboard
模块默认支持不少快捷键,好比:
- 加粗的快捷键是
Ctrl+B
; - 超连接的快捷键是
Ctrl+K
; - 撤销/回退的快捷键是
Ctrl+Z/Y
。
但它不支持删除线的快捷键,若是咱们想定制删除线的快捷键,假设是Ctrl+Shift+S
,能够这样配置:
const quill = new Quill('#editor', { theme: 'snow', modules: { toolbar: [ // 默认的 [{ header: [1, 2, 3, false] }], ['bold', 'italic', 'underline', 'link'], [{ list: 'ordered'}, { list: 'bullet' }], ['clean'], ['image'] ], // 新增的 keyboard: { bindings: { strike: { key: 'S', ctrlKey: true, shiftKey: true, handler: function(range, context) { // 获取当前光标所在文本的格式 const format = this.quill.getFormat(range); // 增长/取消删除线 this.quill.format('strike', !format.strike); } }, } }, } });
配置 history 模块
Quill 内置的history
模块,每隔1s
会记录一次操做历史,并放入历史操做栈(最大100)中,便于撤销/回退操做。
若是咱们不想记录得那么频繁,想2s
记录一次,另外咱们想增长操做栈的大小,最大记录200次操做历史,能够这样配置:
const quill = new Quill('#editor', { theme: 'snow', modules: { toolbar: [ // 默认的 [{ header: [1, 2, 3, false] }], ['bold', 'italic', 'underline', 'link'], [{ list: 'ordered'}, { list: 'bullet' }], ['clean'], ['image'] ], keyboard: { bindings: { strike: { key: 'S', ctrlKey: true, shiftKey: true, handler: function(range, context) { // 获取当前光标所在文本的格式 const format = this.quill.getFormat(range); // 增长/取消删除线 this.quill.format('strike', !format.strike); } }, } }, // 新增的 history: { delay: 2000, // 2s记录一次操做历史 maxStack: 200, // 最大记录200次操做历史 } } });
小结
本文主要介绍了 Quill 的基本用法,以及如何经过 options 选项配置 Quill。
后续将介绍更多关于 Quill 的实践,关注 DevUI 不迷路🦌。
欢迎加DevUI小助手微信:devui-official,一块儿讨论Angular技术和前端技术。
欢迎关注咱们DevUI组件库,点亮咱们的小星星🌟:
https://github.com/devcloudfe/ng-devui
也欢迎使用DevUI新发布的DevUI Admin系统,开箱即用,10分钟搭建一个美观大气的后台管理系统!
加入咱们
咱们是DevUI团队,欢迎来这里和咱们一块儿打造优雅高效的人机设计/研发体系。招聘邮箱:muyang2@huawei.com。
文/DevUI Kagol
往期文章推荐