React中使用UMEditor

最近项目中需要使用富文本编辑器,参考了运营小姐姐日常使用平台上的编辑器,最后考虑采用百度的UMEditor。因为轻量,功能和配置简单,没有很多定制化的功能,所以没采用UEditor。不过我后续会出一篇文章将UEditor的二次开发。

umeditor的引入

组件设计

首先看一下组件大致的内容:
1.组件props:
React中使用UMEditor_第1张图片
UMEditor源码里需要改动的主要就是图片的请求了,配置中的imgUrl我传的是一个方法,这个方法中请求后台并返回Promise<{url:string}>

源码修改

源码修改两个文件
image.js中两处更改
React中使用UMEditor_第2张图片

React中使用UMEditor_第3张图片

UMEditor的源码存放在dll目录下,打包时会被webpack拷贝道相应的目录下,UMEDITOR_HOME_URL和这个目录路径保持一致
React中使用UMEditor_第4张图片

umeditor的依赖处理

文件合并

由于依赖文件过多,我们使用gulp合并一下
React中使用UMEditor_第5张图片
core文件夹下的依赖合并为core.min.js,其他plugin,ui,addapter也一样合并为相应的min.js
原本由editor_api.js引入依赖的,现在我们自己写个方法引入。

依赖加载

组件中定义需要引入的文件,这是一个二维数组,同级的文件按顺序引入,不同级别的可以并发请求,比如:['/third-party/jquery.min.js', '/third-party/template.min.js']中的两个文件同时请求,但是保证它们都load完再请求后面的文件
React中使用UMEditor_第6张图片

加载的时候使用SyncRequire方法
React中使用UMEditor_第7张图片

使用一步迭代器实现可控加载

React中使用UMEditor_第8张图片

好了,有了这个SyncRequire方法,就可以既同时又顺序加载我们的外部js或者css文件了,最后可以在控制台中验证效果
React中使用UMEditor_第9张图片

你可能感兴趣的:(react.js,umeditor,富文本编辑器)