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

VueQuillEditor富文本上傳圖片(非base64)

 更新時間:2020年06月03日 09:17:49   作者:Caeser110  
這篇文章主要介紹了VueQuillEditor富文本上傳圖片(非base64),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

本篇文章將介紹vue-quill-editor上傳圖片的那些事,通常來說,我們數(shù)據(jù)庫內(nèi)都是保存圖片路徑的,所以上傳完圖片之后,要回傳一個路徑給前端,這才是完整的上傳步驟。
第一步:上傳圖片,第二步:保存到服務(wù)器,并且生成路徑保存到數(shù)據(jù)庫,第三步:回傳前端,后臺圖片路徑,前端顯示圖片。

本文中使用了element-ui框架來幫助我完成前端展示工作。

上傳圖片

上傳圖片也有幾種方式,比如直接使用file控件上傳到指定地址,又或者是借助封裝好的上傳按鈕上傳圖片,如果是base64傳到后臺,還需要轉(zhuǎn)回圖片原格式加以保存,如果是二進(jìn)制圖片流則直接傳到服務(wù)器即可。
我使用的是element-ui框架里的el-upload組件進(jìn)行上傳,而且這個組件是隱藏的,不會顯示出來

<el-upload
      class="avatar-uploader"
      :action="articleImgUrl"
      name="img"
      :headers="headerObj"
      :show-file-list="false"
      :on-success="uploadSuccess"
      :on-error="uploadError"
      :before-upload="beforeUpload">
      </el-upload>

上述參數(shù)解釋:
(1)class 上傳組件的樣式,也可以用于查找該組件
(2)action 傳值,必選參數(shù),上傳的地址
(3)name 上傳文件字段名,后端在獲取文件時需要起一個名字,這個名字就在這里定義
(4)headers 設(shè)置上傳的請求頭部
(5) show-file-list 是否顯示已上傳文件列表,這里不顯示
(6) on-success 文件上傳成功時的鉤子,如果成功,則回傳圖片地址,顯示圖片將src傳入地址
(7) on-error 文件上傳失敗時的鉤子
(8)before-upload 上傳文件之前的鉤子,參數(shù)為上傳的文件,若返回 false 或者返回 Promise 且被 reject,則停止上傳。

我首先需要監(jiān)聽富文本點擊上傳圖片按鈕的事件:


editorOption: {
    scrollingContainer: '#editorcontainer',
    placeholder: '',
    // or 'bubble'
    theme: 'snow',
    modules: {
     imageResize: {
      displayStyles: {
       backgroundColor: 'black',
       border: 'none',
       color: 'white'
      },
      modules: ['Resize', 'DisplaySize', 'Toolbar']
     },
     toolbar: {
      // 工具欄
      container: toolbarOptions.toolbarOptions,
      handlers: {
       'image': function (value) {
        if (value) {
         // upload點擊上傳事件
         document.querySelector('.avatar-uploader input').click()
        } else {
         this.quill.format('image', false)
        }
       }
      }
     }
    }
   },

上面代碼當(dāng)中toolbar里的handlers就是監(jiān)聽點擊圖片按鈕事件,然后我們模擬點擊el-upload組件,就會彈出選擇文件的框,我們開始選擇文件進(jìn)行上傳。

當(dāng)后端處理好圖片后,我們拿到回傳的地址,在富文本光標(biāo)處插入img標(biāo)簽


// 上傳成功
  uploadSuccess(res) {
   var dt = res.result
   let quill = this.$refs.myQuillEditor.quill
   // 如果上傳成功
   if (dt.meta.status === this.GLB.IMAGE_ADD_SUCCESS && dt.url !== null) {
    // 獲取光標(biāo)所在位置
    let length = quill.getSelection().index
    // 插入圖片 dt.url為服務(wù)器返回的圖片地址
    quill.insertEmbed(length, 'image', this.glAPI + dt.url)
    // 調(diào)整光標(biāo)到最后
    quill.setSelection(length + 1)
   } else {
    this.$message.error('圖片插入失敗')
   }
   // loading加載隱藏
   this.quillUpdateImg = false
  },

如果小伙伴喜歡原生標(biāo)簽使用input標(biāo)簽file類型也是可以的,或者也可以借助JavaScript或者jQuery響應(yīng)點擊事件來傳文件也是可以噠!

總結(jié)

上傳圖片其實是一個很簡單的過程,但是卻需要前后端來配合食用,味道才正宗。所以只學(xué)前端的小伙伴可以找個后端開發(fā)寫個接口啥的幫你回傳一個地址,或者干脆自己造個假的也行。

我一開始不是很清楚圖片到底怎么傳的,比如base64是什么,其實就是照片的一串字符串,這一串字符串就是照片,有的時候是可能存在把這一串base64字符串保存到數(shù)據(jù)庫的。但是大多數(shù)情況我們還是在數(shù)據(jù)庫中保存路徑,所以很多想保存圖片路徑的小伙伴們,可以參考上述代碼,下一篇我將結(jié)合Java來展示圖片保存的代碼是怎樣實現(xiàn)的,又是怎樣回傳圖片地址的,敬請期待吧!!

到此這篇關(guān)于VueQuillEditor富文本上傳圖片(非base64)的文章就介紹到這了,更多相關(guān)VueQuillEditor富文本上傳圖片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用vux實現(xiàn)上拉刷新功能遇到的坑

    使用vux實現(xiàn)上拉刷新功能遇到的坑

    最近公司在研發(fā)app,選擇了基于Vue框架的vux組件庫,現(xiàn)總結(jié)在實現(xiàn)上拉刷新功能遇到的坑,感興趣的朋友參考下吧
    2018-02-02
  • Vue集成阿里云做滑塊驗證的實踐

    Vue集成阿里云做滑塊驗證的實踐

    滑塊驗證是比較常見的人機鑒別的方法,本文主要介紹了Vue集成阿里云做滑塊驗證,具有一定的參考價值,感興趣的可以了解一下
    2022-01-01
  • vue開發(fā)樹形結(jié)構(gòu)組件(組件遞歸)

    vue開發(fā)樹形結(jié)構(gòu)組件(組件遞歸)

    這篇文章主要為大家詳細(xì)介紹了vue開發(fā)樹形結(jié)構(gòu)組件的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 詳解vue-class遷移vite的一次踩坑記錄

    詳解vue-class遷移vite的一次踩坑記錄

    本文主要介紹了vue-class遷移vite的一次踩坑記錄,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • 淺談Vue?DIFF

    淺談Vue?DIFF

    本文主要介紹了淺談Vue?DIFF,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • vue實現(xiàn)點擊復(fù)制到粘貼板

    vue實現(xiàn)點擊復(fù)制到粘貼板

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)點擊復(fù)制到粘貼板,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • 關(guān)于vue中的時間格式轉(zhuǎn)化問題

    關(guān)于vue中的時間格式轉(zhuǎn)化問題

    這篇文章主要介紹了關(guān)于vue中的時間格式轉(zhuǎn)化問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • elementui下image組件的使用

    elementui下image組件的使用

    本文主要介紹了elementui下image組件的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • 基于mpvue的簡單彈窗組件mptoast使用詳解

    基于mpvue的簡單彈窗組件mptoast使用詳解

    這篇文章主要介紹了基于mpvue的簡單彈窗組件mptoast使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-08-08
  • 在Vue項目中使用Typescript的實現(xiàn)

    在Vue項目中使用Typescript的實現(xiàn)

    這篇文章主要介紹了在Vue項目中使用Typescript的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12

最新評論