React中使用UMEditor的方法示例
最近项目中需要使用富文本编辑器,参考了运营小姐姐日常使用平台上的编辑器,考虑采用百度的UMEditor。因为轻量,功能和配置简单,没有很多定制化的功能,所以没采用UEditor。不过我后续会出一篇文章将UEditor的二次开发。
umeditor的引入
组件设计
看一下组件大致的内容
1.组件props
2.组件关键的成员属性
3.简单的render:
4.UMEditor的实例化
UMEditor源码里需要改动的主要就是图片的请求了,配置中的imgUrl我传的是一个方法,这个方法中请求后台并返回Promise<{url:string}>
源码修改
源码修改两个文件
image.js中两处更改
autoupload.js中一处修改
UMEditor的源码存放在dll目录下,打包时会被webpack拷贝道相应的目录下,UMEDITOR_HOME_URL和这个目录路径保持一致
umeditor的依赖处理
文件合并
由于依赖文件过多,我们使用gulp合并一下
core文件夹下的依赖合并为core.min.js,其他plugin,ui,addapter也一样合并为相应的min.js
原本由editor_api.js引入依赖的,现在我们自己写个方法引入。
依赖加载
组件中定义需要引入的文件,这是一个二维数组,同级的文件按顺序引入,不同级别的可以并发请求,比如['/third-party/jquery.min.js', '/third-party/template.min.js']中的两个文件请求,保证它们都load完再请求后面的文件
加载的时候使用SyncRequire方法
使用一步迭代器实现可控加载
loadDep负责文件加载,具体如下
SyncRequire内部维护一个异步迭代器,迭代的对象是每一个文件的加载。使用for await进行异步迭代
如果是一个文件路径数组,则说明这个数组中的文件可以使用loadDep加载,如果是一个文件路径字符串,则说明这个文件加载完才可以加载后面的文件。loaders具体实现如下
好了,有了这个SyncRequire方法,就可以既又顺序加载我们的外部js或者css文件了,可以在控制台中验证效果
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程