vue+富文本編輯器wangEditor4的使用

1. wangEditor4介紹

wangEditor4 —— 輕量級(jí) web 富文本編輯器静暂,配置方便搏熄,使用簡(jiǎn)單睡毒。支持 IE10+ 瀏覽器来惧。

2. 下載

注意: wangeditor都是小寫(xiě)字母

npm install wangeditor

3. 定義編輯器子組件

  • 創(chuàng)建富文本編輯器子組件 editor.vue

    template

    <template>
      <div class="editor" id="box"></div>
    </template>
    

    script

    import E from "wangeditor";
    export default {
      data() {
        return {};
      },
      mounted() {
        this.initE();
      },
      methods: {
        initE() {
          this.editor = new E("#box");
          //這里各位小伙伴可以查詢官網(wǎng),根據(jù)自己的需求進(jìn)行菜單欄調(diào)整
          this.editor.config.menus = [
            "head", // 標(biāo)題
            "bold", // 粗體
            "fontSize", // 字號(hào)
            "fontName", // 字體
            "italic", // 斜體
            "underline", // 下劃線
            "strikeThrough", // 刪除線
            "foreColor", // 文字顏色
            "backColor", // 背景顏色
            "link", // 插入鏈接
            "list", // 列表
            "justify", // 對(duì)齊方式
            "quote", // 引用
            "emoticon", // 表情
            "image", // 插入圖片
            "table", // 表格
            "code", // 插入代碼
            "undo", // 撤銷
            "redo", // 重復(fù)
          ];
          //為true演顾,則上傳后的圖片轉(zhuǎn)為base64編碼供搀,為false,則上傳圖片到服務(wù)器,二者不能同時(shí)使用
          this.editor.config.uploadImgShowBase64 = false;
          //服務(wù)器接收的上傳圖片的屬性名
          this.editor.config.uploadFileName = "file";
          //服務(wù)器上傳圖片的接口地址
          this.editor.config.uploadImgServer = `http://localhost:3000/upload`;
          // 默認(rèn)限制圖片大小是 5M 钠至,可以自己修改葛虐。
          this.editor.config.uploadImgMaxSize = 2 * 1024 * 1024; // 2M
          // 限制類型,可自定義配置,默認(rèn)為: ['jpg', 'jpeg', 'png', 'gif', 'bmp']
          this.editor.config.uploadImgAccept = ['jpg', 'jpeg',"png", "gif", "bmp", "webp"];
          //上傳圖片過(guò)程中鉤子函數(shù)
          this.editor.config.uploadImgHooks = {
            // 上傳圖片之前
            before: function (xhr) {
              // console.log(xhr);
    
              // // 可阻止圖片上傳
              // return {
              //   prevent: true,
              //   msg: "需要提示給用戶的錯(cuò)誤信息",
              // };
            },
            // 圖片上傳并返回了結(jié)果,圖片插入已成功
            success: function (xhr) {
              console.log("success", xhr);
            },
            // 圖片上傳并返回了結(jié)果棉钧,但圖片插入時(shí)出錯(cuò)了
            fail: function (xhr, editor, resData) {
              console.log("fail", resData);
            },
            // 上傳圖片出錯(cuò)屿脐,一般為 http 請(qǐng)求的錯(cuò)誤
            error: function (xhr, editor, resData) {
              console.log("error", xhr, resData);
            },
            // 上傳圖片超時(shí)
            timeout: function (xhr) {
              console.log("timeout");
            },
          };
        // 在輸入內(nèi)容時(shí),把內(nèi)容傳給父組件
          this.editor.config.onchange = (html) => {
            this.$emit("change", html); // 將內(nèi)容同步到父組件中
          };
          this.editor.create();
          //初始化富文本編輯器時(shí)顯示的內(nèi)容
          this.editor.txt.html("<h1>haha</h1>");
        },
      },
    };
    

4. 圖片上傳注意事項(xiàng)

4.1 響應(yīng)數(shù)據(jù)格式要求

只有響應(yīng)數(shù)據(jù)的格式符合下列要求宪卿,才會(huì)調(diào)用success和fail等回調(diào)函數(shù)

  • 響應(yīng)數(shù)據(jù)格式
{
    // errno 即錯(cuò)誤代碼的诵,0 表示沒(méi)有錯(cuò)誤。
    //       如果有錯(cuò)誤佑钾,errno != 0西疤,可通過(guò)下文中的監(jiān)聽(tīng)函數(shù) fail 拿到該錯(cuò)誤碼進(jìn)行自定義處理
    "errno": 0,

    // data 是一個(gè)數(shù)組,返回圖片Object休溶,Object中包含需要包含url代赁、alt和href三個(gè)屬性,它們分別代表圖片地址撒遣、圖片文字說(shuō)明和跳轉(zhuǎn)鏈接,alt和href屬性是可選的,可以不設(shè)置或設(shè)置為空字符串,需要注意的是url是一定要填的管跺。
    "data": [
        {
            url: "圖片地址",
            alt: "圖片文字說(shuō)明",
            href: "跳轉(zhuǎn)鏈接"
        },
        {
            url: "圖片地址1",
            alt: "圖片文字說(shuō)明1",
            href: "跳轉(zhuǎn)鏈接1"
        },
        "……"
    ]
}
  • 回調(diào)函數(shù)
//上傳圖片過(guò)程中鉤子函數(shù)
      this.editor.config.uploadImgHooks = {
        // 上傳圖片之前
        before: function (xhr) {
          // console.log(xhr);

          // // 可阻止圖片上傳
          // return {
          //   prevent: true,
          //   msg: "需要提示給用戶的錯(cuò)誤信息",
          // };
        },
        // 圖片上傳并返回了結(jié)果,圖片插入已成功
        success: function (xhr) {
          console.log("success", xhr);
        },
        // 圖片上傳并返回了結(jié)果禾进,但圖片插入時(shí)出錯(cuò)了
        fail: function (xhr, editor, resData) {
          console.log("fail", resData);
        },
        // 上傳圖片出錯(cuò)豁跑,一般為 http 請(qǐng)求的錯(cuò)誤
        error: function (xhr, editor, resData) {
          console.log("error", xhr, resData);
        },
        // 上傳圖片超時(shí)
        timeout: function (xhr) {
          console.log("timeout");
        },
      };
  • express后端返回示例

    //圖片上傳
    router.post("/upload", upload.single("file"), (req, res) => {
        // 需要返回圖片的訪問(wèn)地址    域名+上傳文件夾+文件名
        const url = "http://localhost:3000/upload/" + req.file.filename
        res.json({ 
            errno: 0,
            "data": [
                {
                    url,
                    alt: '可愛(ài)',
                    href:"http://www.baidu.com"
                }
            ]
         })
    })
    

4.2 響應(yīng)數(shù)據(jù)不符合格式要求

  • express后端返回示例

    //圖片上傳
    router.post("/upload", upload.single("file"), (req, res) => {
        // 需要返回圖片的訪問(wèn)地址    域名+上傳文件夾+文件名
        const url = "http://localhost:3000/upload/" + req.file.filename
        res.json({url})
    })
    
  • 自定義回調(diào)函數(shù),插入圖片

customInsert: function (insertImgFn, result) {
    //result為上傳圖片成功的時(shí)候返回的數(shù)據(jù)泻云,這里我打印了一下發(fā)現(xiàn)后臺(tái)返回的是data:[{url:"路徑的形式"},...]
    // console.log(result.data[0].url)
    //insertImgFn()為插入圖片的函數(shù)
    //循環(huán)插入圖片
    // for (let i = 0; i < 1; i++) {
    // console.log(result)
    let url = "http://localhost:3000/upload/" + result.url;
    insertImgFn(url);
}

5. 其它API

  • editor.txt.html() 設(shè)置編輯器內(nèi)容艇拍。
  • editor.txt.append('<p>追加的內(nèi)容</p>') 繼續(xù)追加內(nèi)容。
  • editor.txt.html() 獲取 html
  • editor.txt.clear() 清空編輯器內(nèi)容宠纯。

6. 父組件使用富文本編輯器子組件

<template>
  <div id="app">
    <editor @change="change"></editor>
    <button @click="send()">提交</button>
  </div>
</template>

<script>
import editor from "@/views/editor.vue";
export default {
  components: { editor },
  data(){
    return {
      result: ''
    }
  },
  methods: {
    //提交富文本編輯器的內(nèi)容
    send(){
      console.log('send',this.result);
    },
    change(html){
      this.result = html
    }
  }
  
};
</script>

<style lang="scss">
</style>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末卸夕,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子婆瓜,更是在濱河造成了極大的恐慌快集,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,544評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件廉白,死亡現(xiàn)場(chǎng)離奇詭異个初,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)猴蹂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門院溺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人磅轻,你說(shuō)我怎么就攤上這事珍逸。” “怎么了聋溜?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,764評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵谆膳,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我勤婚,道長(zhǎng)摹量,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,193評(píng)論 1 292
  • 正文 為了忘掉前任馒胆,我火速辦了婚禮缨称,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘祝迂。我一直安慰自己睦尽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布型雳。 她就那樣靜靜地躺著当凡,像睡著了一般山害。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上沿量,一...
    開(kāi)封第一講書(shū)人閱讀 51,182評(píng)論 1 299
  • 那天浪慌,我揣著相機(jī)與錄音,去河邊找鬼朴则。 笑死权纤,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的乌妒。 我是一名探鬼主播汹想,決...
    沈念sama閱讀 40,063評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼撤蚊!你這毒婦竟也來(lái)了古掏?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,917評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤侦啸,失蹤者是張志新(化名)和其女友劉穎槽唾,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體匹中,經(jīng)...
    沈念sama閱讀 45,329評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡夏漱,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了顶捷。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片挂绰。...
    茶點(diǎn)故事閱讀 39,722評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖服赎,靈堂內(nèi)的尸體忽然破棺而出葵蒂,到底是詐尸還是另有隱情,我是刑警寧澤重虑,帶...
    沈念sama閱讀 35,425評(píng)論 5 343
  • 正文 年R本政府宣布践付,位于F島的核電站,受9級(jí)特大地震影響缺厉,放射性物質(zhì)發(fā)生泄漏永高。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評(píng)論 3 326
  • 文/蒙蒙 一提针、第九天 我趴在偏房一處隱蔽的房頂上張望命爬。 院中可真熱鬧,春花似錦辐脖、人聲如沸饲宛。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,671評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)艇抠。三九已至幕庐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間家淤,已是汗流浹背异剥。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,825評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留絮重,地道東北人届吁。 一個(gè)月前我還...
    沈念sama閱讀 47,729評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像绿鸣,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子暂氯,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容