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

解決vue-quill-editor上傳內(nèi)容由于圖片是base64的導(dǎo)致字符太長的問題

 更新時間:2018年08月20日 14:23:21   作者:燦爺?shù)那岸酥? 
vue-quill-editor默認插入圖片是直接將圖片轉(zhuǎn)為base64再放入內(nèi)容中,如果圖片較多,篇幅太長,就會比較煩惱,接下來通過本文給大家介紹vue-quill-editor上傳內(nèi)容由于圖片是base64的導(dǎo)致字符太長的問題及解決方法,需要的朋友可以參考下

vue-quill-editor是個較為輕量級富文本框,相較于ueditor,開發(fā)更編輯,更加直觀,如果大家伙在需求允許的情況下,還是會比較建議使用vue-quill-editor。

vue-quill-editor的使用方法在這邊就不多說了,大家網(wǎng)上查下,一抓一大把

但是在使用vue-quill-editor有一個致命的問題,vue-quill-editor默認插入圖片是直接將圖片轉(zhuǎn)為base64再放入內(nèi)容中,如果圖片比較大的話,富文本的內(nèi)容就會很大,即使圖片不大,只要圖片較為多,篇幅較長,富文本的內(nèi)容也是異常的大的,這就會給大家?guī)硪恍溃覀兛赡芨M谔峤桓晃谋镜膬?nèi)容的時候圖片只是以圖片地址提交,那這樣一來我們要怎么去處理呢,接下來大家可以來理一理

還是老思路,既然我們可以希望不是直接將圖片轉(zhuǎn)成base64,那么我們可以采用選擇完圖片,即將圖片上傳服務(wù)器,服務(wù)器返回相應(yīng)的圖片鏈接,前端將圖片鏈接插入到富文本的指定光標上即可,這樣一來就可以實現(xiàn)我們的想要的效果了

首先,新建富文本組件QuillEditor.vue,利用iview的上傳組件來上傳選擇完的圖片(當(dāng)然,其他的上傳組件也是ok的)

<Upload
    id="iviewUp"
     ref="upload"
     :show-upload-list="false"
     :on-success="handleSingleSuccess"
     :format="['jpg','jpeg','png']"
     :max-size="2048"
     :headers="header"
     :on-format-error="handleFormatError"
     :before-upload="handleBeforeUpload()"
     type="drag"
     :action="serverUrl"
     style="display: none;width:0">
     <div style="width: 0">
       <Icon type="ios-camera" size="50"></Icon>
     </div>
   </Upload>
   <!--<Row>-->
    <quill-editor 
     v-model="detailContent" 
     ref="myQuillEditor" 
     :options="editorOption" 
     @blur="onEditorBlur($event)" @focus="onEditorFocus($event)"
     @change="onEditorChange($event)">
    </quill-editor>
   <!--</Row>-->

看到上面的代碼有的的就會有疑問了,那上傳好的圖片要怎么插到富文本的指定光標里面呢,別慌,面包會有的,往下看,

handleSingleSuccess (res, file) {
   // res為圖片服務(wù)器返回的數(shù)據(jù)
   // 獲取富文本組件實例
   let vm = this
   let quill = this.$refs.myQuillEditor.quill
   console.log('res---', vm.$refs.myQuillEditor.quill.getSelection())
   // 如果上傳成功
   if (res.res_code === '1') {
     // 獲取光標所在位置
     let length = quill.getSelection().index;
     // 插入圖片 res.info為服務(wù)器返回的圖片地址
     quill.insertEmbed(length, 'image', res.result.url)
     // 調(diào)整光標到最后
     quill.setSelection(length + 1)
   } else {
     vm.$Message.error('圖片插入失敗')
   }
   // loading動畫消失
   this.quillUpdateImg = false
  }

通過 this.$refs.myQuillEditor.quill.getSelection().index獲取光標所在位置,將圖片地址放在該位置即可

這樣一來萬事俱備,只欠東風(fēng)了,這個時候大家會發(fā)現(xiàn),那iview這個上傳組件在頁面上呢,我怎么實現(xiàn)點擊富文本上的上傳圖片的按鈕調(diào)用iview的上傳組件的方法呢,

這個時候我們就要用到富文本中的配置屬性editorOption,對editorOption進行圖片上傳的點擊事件進行相應(yīng)的配置即可,詳情看下面代碼

 editorOption: { // 富文本框配置
     placeholder: '',
     theme: 'snow', // or 'bubble'
     modules: {
       toolbar: {
         container: toolbarOptions, // 工具欄
         handlers: {
           'image': function (value) {
 

if (value) {
               document.querySelector('#iviewUp input').click()
             } else {
               this.quill.format('image', false);
             }
           }
         }
       }
     }
   }

 document.querySelector('#iviewUp input') 這個就是相應(yīng)的dom節(jié)點的點擊事件,將其綁在富文本的圖片按鈕點擊事件上好了,基本上大功告成。還是算比較簡單的,希望可以供大家參考

總結(jié)

以上所述是小編給大家介紹的解決vue-quill-editor上傳內(nèi)容由于圖片是base64的導(dǎo)致字符太長的問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue實現(xiàn)登錄注冊模板的示例代碼

    vue實現(xiàn)登錄注冊模板的示例代碼

    這篇文章主要介紹了vue實現(xiàn)登錄注冊模板的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • vue中v-for循環(huán)選中點擊的元素并對該元素添加樣式操作

    vue中v-for循環(huán)選中點擊的元素并對該元素添加樣式操作

    這篇文章主要介紹了vue中v-for循環(huán)選中點擊的元素并對該元素添加樣式操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • 基于vue項目設(shè)置resolves.alias: ''@''路徑并適配webstorm

    基于vue項目設(shè)置resolves.alias: ''@''路徑并適配webstorm

    這篇文章主要介紹了基于vue項目設(shè)置resolves.alias: '@'路徑并適配webstorm,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-12-12
  • Vue基礎(chǔ)教程之條件渲染和列表渲染

    Vue基礎(chǔ)教程之條件渲染和列表渲染

    Vue會盡可能高效地渲染元素,通常會復(fù)用已有元素而不是從頭開始渲染。這么做會使Vue變得非???下面這篇文章主要給大家介紹了Vue基礎(chǔ)教程之條件渲染和列表渲染的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • Vue異步請求導(dǎo)致頁面數(shù)據(jù)渲染錯誤問題解決方法示例

    Vue異步請求導(dǎo)致頁面數(shù)據(jù)渲染錯誤問題解決方法示例

    這篇文章主要為大家介紹了Vue中異步請求導(dǎo)致頁面數(shù)據(jù)渲染錯誤問題解決方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • 解決vue修改數(shù)據(jù)頁面不重新渲染問題

    解決vue修改數(shù)據(jù)頁面不重新渲染問題

    這篇文章詳細介紹了vue渲染機制和如何解決數(shù)據(jù)修改頁面不刷新問題的多種方法,想了解更多的小伙伴可以借鑒閱讀
    2023-03-03
  • 詳解mpvue scroll-view自動回彈bug解決方案

    詳解mpvue scroll-view自動回彈bug解決方案

    設(shè)置了scroll-top的scroll-view組件,在組件所在vue實例data發(fā)生改變時會自動回彈到最上方,非常具有實用價值,需要的朋友可以參考下
    2018-10-10
  • antd配置config-overrides.js文件的操作

    antd配置config-overrides.js文件的操作

    這篇文章主要介紹了antd配置config-overrides.js文件的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • vscode中使用vue的一些插件總結(jié)(方便開發(fā))

    vscode中使用vue的一些插件總結(jié)(方便開發(fā))

    對于很多使用vscode編寫vue項目的新手同學(xué)來說,可能不知道使用什么插件,下面這篇文章主要給大家介紹了關(guān)于vscode中使用vue的一些插件,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2022-11-11
  • vue.js如何將echarts封裝為組件一鍵使用詳解

    vue.js如何將echarts封裝為組件一鍵使用詳解

    Echarts 、 Remodal和Pikaday是我們在開發(fā)后臺管理類網(wǎng)站時常用的三個第三方組件,下面這篇文章主要給大家介紹了關(guān)于vue.js如何將echarts封裝為組件一鍵使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下。
    2017-10-10

最新評論