欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解vue中使用vue-quill-editor富文本小結(jié)(圖片上傳)

 更新時間:2019年04月24日 14:11:08   作者:大盤雞拌面  
這篇文章主要介紹了詳解vue中使用vue-quill-editor富文本小結(jié)(圖片上傳),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

vue-quill-editor是我們再使用vue框架的時候常用的一個富文本編輯器,在進行富文本編輯的時候,我們往往要插入一些圖片,vue-quill-editor默認(rèn)的處理方式是直接將圖片轉(zhuǎn)成base64編碼,這樣的結(jié)果是整個富文本的html片段十分冗余,通常來講,每個服務(wù)器端接收的post的數(shù)據(jù)大小都是有限制的,這樣的話有可能導(dǎo)致提交失敗,或者是用戶體驗很差,數(shù)據(jù)要傳遞很久才全部傳送到服務(wù)器。

1.下載Vue-Quill-Editor

npm install vue-quill-editor --save

2.下載quill(Vue-Quill-Editor需要依賴)

npm install quill --save

3.使用

import { quillEditor } from "vue-quill-editor"; //調(diào)用編輯器
import 'quill/dist/quill.core.css';
import 'quill/dist/quill.snow.css';
import 'quill/dist/quill.bubble.css';

本次使用到了富文本的封裝和上傳圖片,因要求使用element-ui框架,我上傳圖片的時候選擇了element-ui的Upload上傳組件將圖片上傳到服務(wù)器。再將圖片鏈接插入到富文本中,以達到最優(yōu)的體驗。

子組件中將改變的值,直接發(fā)送給父組件,父組件來完成邏輯處理

<template>
 <div>
  <el-upload      //直接隱藏掉就好了,用功能不用樣式
   v-show="false"
   id="quill-upload"
   action="/api/product/upload.do"
   name="upload_file"
   multiple
   :limit="3"
   list-type="picture"
   :show-file-list="false"
   :before-upload="beforeUpload"
   :on-error="uploadError"
   :on-success="handleExceed">
   <el-button size="small" type="primary" ></el-button>
   <div slot="tip" class="el-upload__tip">只能上傳jpg/png文件,且不超過500kb</div>
  </el-upload>
  <el-row v-loading="uillUpdateImg">
   <quillEditor
    ref="myQuillEditor"
    @change="onEditorChange($event)"
    v-model="value"
    :options="editorOption"/>
  </el-row>
 </div>
</template>
<script>
import { quillEditor } from 'vue-quill-editor'
import 'quill/dist/quill.core.css'
import 'quill/dist/quill.snow.css'
import 'quill/dist/quill.bubble.css'
export default {
 name: "richText",
 components:{quillEditor},
 props:['content'],               //父組件傳過來的,將傳過來的渲染到富文本編輯器
 data(){
  return{
   uillUpdateImg:false,            //根據(jù)圖片上傳狀態(tài)來確定是否顯示loading動畫
   serverUrl:'', //上傳的圖片服務(wù)器地址
   value:this.content,             //富文本內(nèi)容
   editorOption: {               //符文本編輯器的配置
    placeholder: '',
    theme: 'snow',
    modules: {
     toolbar: {
      container: [             // 工具欄配置, 默認(rèn)是全部
       ['bold'],
       ['italic'],
       ['underline'],
       ['strike'],
       [{'list':'ordered'},{'list': 'bullet' }],
       ['blockquote'], ['code-block'],
       ['link'],
       ['image'],
       [{'list': 'ordered'}, {'list': 'bullet'}],
      ],
      handlers: {
       'image': function (value) {
        if (value) {
         // 給個點擊觸發(fā)Element-ui,input框選擇圖片文件
         document.querySelector('#quill-upload input').click()
        } else {
         this.quill.format('image', false);
        }
       }
      }
     }
    }
   }
  }
 },
 methods:{
  onEditorChange({ quill, html, text }) {   //富文本編輯器內(nèi)容發(fā)生改變的時候
   this.value = html
   this.$emit('textChange',html)       //將富文本編輯器輸入的文本發(fā)送給父組件,父組件涉及提交添加或者更改
  },
  beforeUpload(){               //上傳圖片之前開啟loading
   this.uillUpdateImg = true
  },
  uploadError(){               //圖片上傳失敗,關(guān)閉loading
   this.uillUpdateImg = false
   this.$message.error('圖片插入失敗')
  },
  handleExceed(response, file, fileList){   //圖片添加成功
   let quill = this.$refs.myQuillEditor.quill
   console.log(response)
   if (response.status === 0) {
    let length = quill.getSelection().index;
    // 插入圖片 response.data.url為服務(wù)器返回的圖片地址
    quill.insertEmbed(length, 'image', response.data.url)
    // 調(diào)整光標(biāo)到最后
    quill.setSelection(length + 1)
   }else{
    this.$message.error('圖片插入失敗')
   }
   this.fileList = fileList
   this.uillUpdateImg = false
  },
 }
}
</script>
<style scoped>
</style>

配置中的handlers是用來定義自定義程序的,然而我們配置完后會懵逼地發(fā)現(xiàn),整個富文本編輯器的工具欄的圖片上傳等按鈕都不見了 只保留了幾個基本的富文本功能。

這個是因為添加自定義處理程序?qū)⒏采w默認(rèn)的工具欄和主題行為

因此我們要再自行配置下我們需要的工具欄,所有功能的配置如下,大家可以按需配置,這里看起來一大堆,也不美觀,大家也可以配置一個單獨的config文件引入。

有一點注意的地方,父組件中傳入子組件中的值,子組件里面發(fā)生改變以后再傳給父組件。將變量時存放在props屬性中的,我們在調(diào)用變量的時候是跟data里面的變量一樣的,都是通過this.變量來調(diào)用,這個問題就是說父組件傳入子組件的變量是不能this.變量直接改變的,要在data或者computed屬性里面重新定義一個變量,或者監(jiān)聽props接受變量的變化。改變data或者computed屬性里面的變量就不會報錯了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue 不使用select實現(xiàn)下拉框功能(推薦)

    vue 不使用select實現(xiàn)下拉框功能(推薦)

    這篇文章主要介紹了vue 不使用select實現(xiàn)下拉框功能,在文章給大家提到了vue select 組件的使用與禁用,需要的朋友可以參考下
    2018-05-05
  • vue實現(xiàn)信息管理系統(tǒng)

    vue實現(xiàn)信息管理系統(tǒng)

    這篇文章主要為大家詳細介紹了vue實現(xiàn)信息管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • vue3實現(xiàn)在新標(biāo)簽中打開指定網(wǎng)址的方法

    vue3實現(xiàn)在新標(biāo)簽中打開指定網(wǎng)址的方法

    我希望點擊查看按鈕的時候,能夠在新的標(biāo)簽頁面打開這個文件的地址進行預(yù)覽,該如何實現(xiàn)呢,下面小編給大家?guī)砹嘶趘ue3實現(xiàn)在新標(biāo)簽中打開指定的網(wǎng)址,感興趣的朋友跟隨小編一起看看吧
    2024-07-07
  • 基于Vue中點擊組件外關(guān)閉組件的實現(xiàn)方法

    基于Vue中點擊組件外關(guān)閉組件的實現(xiàn)方法

    下面小編就為大家分享一篇基于Vue中點擊組件外關(guān)閉組件的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue實現(xiàn)公告欄文字上下滾動效果的示例代碼

    vue實現(xiàn)公告欄文字上下滾動效果的示例代碼

    這篇文章主要介紹了vue實現(xiàn)公告欄文字上下滾動效果的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Vue echarts繪制甘特圖的示例代碼

    Vue echarts繪制甘特圖的示例代碼

    甘特圖是一種條狀圖,直觀展示項目進展隨時間的走勢及聯(lián)系,其中,項目時間由橫軸表示,項目活動由縱軸表示,本文給大家介紹了Vue echarts繪制甘特圖的實現(xiàn)方法,并有詳細的代碼示例供大家參考,需要的朋友可以參考下
    2024-03-03
  • vue3在table里使用elementUI的form表單驗證的示例代碼

    vue3在table里使用elementUI的form表單驗證的示例代碼

    這篇文章主要介紹了vue3在table里使用elementUI的form表單驗證的示例代碼,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-12-12
  • 解析VUE中nextTick是什么

    解析VUE中nextTick是什么

    nextTick是Vue提供的一個全局API,由于Vue的異步更新策略導(dǎo)致我們對數(shù)據(jù)的修改不會立刻體現(xiàn),在DOM變化上,此時如果想要立即獲取更新后的DOM狀態(tài),就需要使用這個方法,這篇文章主要介紹了解析VUE中nextTick,需要的朋友可以參考下
    2022-11-11
  • 在Vue-cli里應(yīng)用Vuex的state和mutations方法

    在Vue-cli里應(yīng)用Vuex的state和mutations方法

    今天小編就為大家分享一篇在Vue-cli里應(yīng)用Vuex的state和mutations方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue組件之間的數(shù)據(jù)共享詳解

    Vue組件之間的數(shù)據(jù)共享詳解

    這篇文章主要為大家介紹了Vue組件之間的數(shù)據(jù)共享,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11

最新評論