React中使用UMEditor的方法示例
最近項目中需要使用富文本編輯器,參考了運營小姐姐日常使用平臺上的編輯器,最后考慮采用百度的UMEditor。因為輕量,功能和配置簡單,沒有很多定制化的功能,所以沒采用UEditor。不過我后續(xù)會出一篇文章將UEditor的二次開發(fā)。
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引入依賴的,現在我們自己寫個方法引入。
依賴加載
組件中定義需要引入的文件,這是一個二維數組,同級的文件按順序引入,不同級別的可以并發(fā)請求,比如:['/third-party/jquery.min.js', '/third-party/template.min.js']中的兩個文件同時請求,但是保證它們都load完再請求后面的文件
加載的時候使用SyncRequire方法
使用一步迭代器實現可控加載
loadDep負責文件加載,具體如下:
SyncRequire內部維護一個異步迭代器,迭代的對象是每一個文件的加載。最后使用for await進行異步迭代
如果是一個文件路徑數組,則說明這個數組中的文件可以同時使用loadDep加載,如果是一個文件路徑字符串,則說明這個文件加載完才可以加載后面的文件。loaders具體實現如下
好了,有了這個SyncRequire方法,就可以既同時又順序加載我們的外部js或者css文件了,最后可以在控制臺中驗證效果
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Remix 后臺桌面開發(fā)electron-remix-antd-admin
這篇文章主要為大家介紹了Remix 后臺桌面開發(fā)electron-remix-antd-admin的過程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04React如何使用refresh_token實現無感刷新頁面
本文主要介紹了React如何使用refresh_token實現無感刷新頁面,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-04-04Create?react?app修改webapck配置導入文件alias
這篇文章主要為大家介紹了Create?react?app修改webapck配置導入文件alias,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-12-12