React中使用UMEditor的方法示例
最近項(xiàng)目中需要使用富文本編輯器,參考了運(yùn)營(yíng)小姐姐日常使用平臺(tái)上的編輯器,最后考慮采用百度的UMEditor。因?yàn)檩p量,功能和配置簡(jiǎn)單,沒(méi)有很多定制化的功能,所以沒(méi)采用UEditor。不過(guò)我后續(xù)會(huì)出一篇文章將UEditor的二次開(kāi)發(fā)。
umeditor的引入
組件設(shè)計(jì)
首先看一下組件大致的內(nèi)容:
1.組件props:

2.組件關(guān)鍵的成員屬性:

3.簡(jiǎn)單的render:

4.UMEditor的實(shí)例化

UMEditor源碼里需要改動(dòng)的主要就是圖片的請(qǐng)求了,配置中的imgUrl我傳的是一個(gè)方法,這個(gè)方法中請(qǐng)求后臺(tái)并返回Promise<{url:string}>
源碼修改
源碼修改兩個(gè)文件
image.js中兩處更改


autoupload.js中一處修改

UMEditor的源碼存放在dll目錄下,打包時(shí)會(huì)被webpack拷貝道相應(yīng)的目錄下,UMEDITOR_HOME_URL和這個(gè)目錄路徑保持一致

umeditor的依賴處理
文件合并
由于依賴文件過(guò)多,我們使用gulp合并一下

core文件夾下的依賴合并為core.min.js,其他plugin,ui,addapter也一樣合并為相應(yīng)的min.js
原本由editor_api.js引入依賴的,現(xiàn)在我們自己寫(xiě)個(gè)方法引入。
依賴加載
組件中定義需要引入的文件,這是一個(gè)二維數(shù)組,同級(jí)的文件按順序引入,不同級(jí)別的可以并發(fā)請(qǐng)求,比如:['/third-party/jquery.min.js', '/third-party/template.min.js']中的兩個(gè)文件同時(shí)請(qǐng)求,但是保證它們都load完再請(qǐng)求后面的文件

加載的時(shí)候使用SyncRequire方法

使用一步迭代器實(shí)現(xiàn)可控加載

loadDep負(fù)責(zé)文件加載,具體如下:

SyncRequire內(nèi)部維護(hù)一個(gè)異步迭代器,迭代的對(duì)象是每一個(gè)文件的加載。最后使用for await進(jìn)行異步迭代

如果是一個(gè)文件路徑數(shù)組,則說(shuō)明這個(gè)數(shù)組中的文件可以同時(shí)使用loadDep加載,如果是一個(gè)文件路徑字符串,則說(shuō)明這個(gè)文件加載完才可以加載后面的文件。loaders具體實(shí)現(xiàn)如下

好了,有了這個(gè)SyncRequire方法,就可以既同時(shí)又順序加載我們的外部js或者css文件了,最后可以在控制臺(tái)中驗(yàn)證效果

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
React組件創(chuàng)建與事件綁定的實(shí)現(xiàn)方法
react事件綁定時(shí)。this并不會(huì)指向當(dāng)前DOM元素。往往使用bind來(lái)改變this指向,今天通過(guò)本文給大家介紹React事件綁定的方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-12-12
詳解使用React全家桶搭建一個(gè)后臺(tái)管理系統(tǒng)
本篇文章主要介紹了使用React全家桶搭建一個(gè)后臺(tái)管理系統(tǒng),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11
React-Native之定時(shí)器Timer的實(shí)現(xiàn)代碼
本篇文章主要介紹了React-Native之定時(shí)器Timer的實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
React+TypeScript+webpack4多入口配置詳解
這篇文章主要介紹了React+TypeScript+webpack4多入口配置詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
詳解React開(kāi)發(fā)必不可少的eslint配置
本篇文章主要介紹了詳解React開(kāi)發(fā)必不可少的eslint配置,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02

