优势
其他富文本编辑器的问题
网络搜索“Web 富文本编辑器”你会得到很多结果,例如国内的 UEditor kindEditor ,国外的 CKEditor TinyMCE Quill ProseMirror Draft Slate 等等。也有很多人使用这些编辑器,或者来做二次开发。
但他们都存在下面几个问题(敲黑板~),这可能会大大影响你的开发效率、开发成本和产品稳定性。
技术老旧
如 UEditor KindEditor ,依然使用 document.execCommand
API 。这将大大影响产品的稳定性、扩展性。
到时候啥啥都实现不了,哪儿哪儿都有问题,会被 PM 鄙视:“人家 xxx 咋能行?”
中文不友好
如 CKEditor TinyMCE Quill ProseMirror 等,没有官方的中文文档。这将大大影响你的开发效率(今晚加班~)
PS:英语特别好的,请略过。
需要大量二次开发
如 ProseMirror Draft Slate ,他们虽然也是富文本编辑器,但他们仅仅是一个 core 或者 controller ,并不是一个完整的功能。
大量的二次开发,不仅仅会导致研发成本大增(本月封闭~),还可能因为测试不完善而出现无尽的 bug ,陷入泥潭。
PS:除非你们有强烈的定制开发需要。
有框架的约束
如 Slate 和 Draft ,是依赖于 React 框架的。如果你想用到 Vue 中,工作量和难度是非常大的。
无官方 React Vue 等组件
一些无框架依赖的,如 ProseMirror ,如果你要用到 Vue React ,需要自己封装组件。
新产品尚未稳定
上述列出来的编辑器,都是比较成熟的产品,用户量较大。你可能还会搜到其他产品,如新开发的、用户量不大的。
无论如何,请你慎重选择,因为富文本编辑器的坑真的太多了,需要经过大量的测试、使用才会慢慢稳定。
选择稳定的产品,可参考
- github stars
- npm 下载量
- npm 发布时间和频率
- 搜索引擎的相关结果数量
- 是否有大厂背书
- 是否有单元测试 / e2e 测试
wangEditor 的优势
一个产品的价值,就在于解决用户的问题,提高效率、降低成本、增加稳定性和扩展性。
wangEditor 不是为了做而做,也不是单纯的模仿谁,而是经过上述问题分析之后,给出一个系统的解决方案。旨在真正去解决用户的问题,产出自己的价值。
使用主流技术
wangEditor 从 V5 版本开始,有较大的技术更新。
1. 升级为 L1 能力
弃用了 document.execCommand
API ,使用 slate.js(但不依赖 React)为内核,升级为 L1 能力。
这也是目前主流富文本编辑器的技术方案,如知名的 Quill ProseMirror Draft 都在使用。
2. 使用 vdom
使用 vdom 技术(基于 snabbdom.js )做视图更新,model 和 view 分离,增加稳定性。
3. 扩展性
使用扩展插件和模块的机制,保证扩展性。未来还会继续扩展更多功能。
其实,现在 wangEditor 内置的各个功能,也都是通过扩展插件和模块的形式搭建起来的。
中文文档
wangEditor 有详细的中文文档,以及中文交流环境。因为作者就是国内程序员。
及时反馈和沟通
也可以去 github 提交 issue ,团队都会及时反馈或受理。
集成所有功能,无需二次开发
wangEditor 内置了所有常见的富文本操作功能,能满足绝大部分使用需求。直接配置使用即可,无需再二次开发。
// wangEditor 已内置 50+ 菜单
editor.getAllMenuKeys()
[
"bold","underline","italic","through","code","clearStyle","headerSelect","header1","header2","header3",
"color","bgColor","insertLink","editLink","unLink","viewLink","insertImage","deleteImage","editImage",
"viewImageLink","imageWidth30","imageWidth50","imageWidth100","blockquote","emotion","fontSize","fontFamily",
"indent","delIndent","justifyLeft","justifyRight","justifyCenter","lineHeight","redo","undo","divider","codeBlock",
"bulletedList","numberedList","insertTable","deleteTable","insertTableRow","deleteTableRow","insertTableCol",
"deleteTableCol","tableHeader","tableFullWidth","insertVideo","deleteVideo","uploadImage","codeSelectLang"
]
PS:同时,wangEditor 有丰富的 API 和足够的扩展性,允许你自定义开发菜单、模块、插件等。
很方便的应用于 Vue React
wangEditor 基于 slate 内核开发,但不依赖于 React ,所以它本身是无框架依赖的。
并且,我们官方封装了 Vue React 组件,可以很方便的用于 Vue React 等框架。
其他框架,我们会继续支持,大家也可以提交 issue 。
踩过 5000 个坑
wangEditor 开源多年,大量用户使用和反馈,已经解决了很多问题。在 V5 版本测试过程中,也这些问题进行了重复测试,最大程度保证稳定性。
团队作业,持续迭代升级
wangEditor 早已不是作者单人作战,我们有多人团队,一起修复 bug 、升级功能、跟踪问题、社区答疑。