前言
使用vue-cli3.0+element-ui+webpack做專案時,遇到了一個需求:文章管理中新增富文字編輯器(暫未新增上傳圖片功能),在百度上檢視到好幾個富文字編輯器,最終選擇了百度的Ueditor
,基本能滿足所有需求。經過多番採坑之後,已實現相關功能,特此做一個記錄。
一、下載Ueditor相關靜態檔案存放位置
首先去Ueditor官網下載相關資源(本文下載的1.4.3.3Jsp版本):
data:image/s3,"s3://crabby-images/bd4b3/bd4b3905a81e7990e5a5e862bf1cc3da57d69fc1" alt="Ueditor相關資原始檔"
vue-cli2
與vue-cli3
進行區分。
vue-cli2
vue-cli2
版本中會生成一個static
資料夾,用於放置靜態資源,將下載的壓縮包解壓後放入static
資料夾中:
data:image/s3,"s3://crabby-images/2c4d0/2c4d0bd23a63692291dbdc5195d61cc61de9af33" alt="Vue整合Ueditor"
vue-cli3
vue-cli3
在專案初始化時會生成一個public
資料夾(public資料夾使用場景,public
資料夾中的檔案不會被webpack打包編譯,只是簡單的複製到打包後的dist
資料夾中)。將下載的壓縮包解壓並重新命名UE
放入public
資料夾中:
data:image/s3,"s3://crabby-images/45dcd/45dcdbb46efa244671854a104a35cd88e3dc7ac6" alt="解壓後的Ueditor存放目錄"
二、引入vue-ueditor-wrap後的相關配置
先安裝vue-ueditor-wrap
,然後在相關元件中引入vue-ueditor-wrap
npm i vue-ueditor-wrap -D
複製程式碼
在相關元件中註冊並引入:
data:image/s3,"s3://crabby-images/5bb6b/5bb6b553399276607737f67d442b40c330b2cca0" alt="Vue整合Ueditor"
data:image/s3,"s3://crabby-images/e9f12/e9f12584d50534ab07dd5250af5420a9ca96f20d" alt="Vue整合Ueditor"
data:image/s3,"s3://crabby-images/43754/43754bcbba139b77cf050f5ecc8f77224bafcb32" alt="Vue整合Ueditor"
重點主要在myconfig
配置引數上(詳細配置引數見UE/ueditor.config.js
),在vue-cli2
與vue-cli3
上略顯不同。
vue-cli2
專案使用vue-cli2
進行搭建並且將UE
資料夾複製到了static
資料夾中(如第一點所示),UEDITOR_HOME_URL
配置為:
data:image/s3,"s3://crabby-images/26c1d/26c1d1980f8f8af28c3e08f06138975b56e283dd" alt="Vue整合Ueditor"
ueditor.config.js
中的UEDITOR_HOME_URL為'/UE/'
data:image/s3,"s3://crabby-images/9ebde/9ebdeeb76dfb2336c93a52c19169c7ec68f7cf9a" alt="Vue整合Ueditor"
vue-cli3
使用vue-cli3
的UEDITOR_HOME_URL
配置為:
data:image/s3,"s3://crabby-images/00a12/00a122a2a68c0a9db742da69fc65fdf51bc2e054" alt="Vue整合Ueditor"
ueditor.config.js
中的UEDITOR_HOME_URL
為'/static/UE/'
data:image/s3,"s3://crabby-images/de139/de139f6c1d5e892452b857daf51b8a1fb3630fca" alt="Vue整合Ueditor"
data:image/s3,"s3://crabby-images/e705c/e705c071d1e947e0a88b14fdd302b21c23b9c587" alt="Vue整合Ueditor"
三、修改富文字內容長度計算方式
該Ueditor中的內容長度(在這裡僅以vue
雙向繫結為例)都是按照1個字元長度進行計算的,如插入一個表情顯示長度為1:
data:image/s3,"s3://crabby-images/11d8f/11d8f7d26600a34613273eba379318b7f7a3cc91" alt="Vue整合Ueditor"
ueditor.all.js
或者ueditor.all.min.js
的原始碼。
修改ueditor.all.js
的方式
在ueditor.all.js
檔案中全域性查詢getContentLength
:
data:image/s3,"s3://crabby-images/2afb0/2afb01b8131a11cdf20f6d6f8d057c9e37a53552" alt="Vue整合Ueditor"
ueditor.all.min.js
檔案即可
data:image/s3,"s3://crabby-images/b1def/b1defd45133e587f2e2565965c3447dd93988f0e" alt="Vue整合Ueditor"
修改ueditor.all.min.js
的方式
該方式比較簡單粗暴,直接在ueditor.all.min.js
中全域性搜尋getContentLength
並刪除高亮部分:
data:image/s3,"s3://crabby-images/42942/42942776a5d7bf3295abd241943c0233b49a7f13" alt="Vue整合Ueditor"
data:image/s3,"s3://crabby-images/cd207/cd207e651253fa8414e833fc31c9ccdc463728b7" alt="Vue整合Ueditor"
四、其他問題
如在配置中出現下圖類似問題:
data:image/s3,"s3://crabby-images/9799d/9799d4738eb037c96807e7ceeca564f35d3832bf" alt="Vue整合Ueditor"
UEDITOR_HOME_URL
路徑是否正確。仔細檢查!仔細檢查!仔細檢查!重要的事情說三遍~
最後
希望本文能幫助到有需要的你~
data:image/s3,"s3://crabby-images/0512d/0512d3a8305ef77b495821cee7d3017e20717221" alt="Vue整合Ueditor"
vue-ueditor-wrap