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

Element plus實現(xiàn)圖片手動上傳與回顯的過程

 更新時間:2024年09月22日 08:53:50   作者:哪里的破水瓶  
近期,發(fā)現(xiàn)點擊修改,element ui 的圖片沒有回顯到框中,所以本文給大家介紹了Element plus實現(xiàn)圖片手動上傳與回顯的過程,文中通過代碼示例給大家介紹的非常詳細,具有一定的參考價值,需要的朋友可以參考下

1. 圖片手動上傳,等待上傳成功。

這里關(guān)鍵點設(shè)置關(guān)閉自動上傳,用于手動提交,設(shè)置上傳地址和請求頭信息。success函數(shù)和error函數(shù)監(jiān)聽結(jié)果。

  • :auto-upload="false":禁止自動上傳
  • :action=uploadUrl 設(shè)置上傳地址
  • :headers="headers" 設(shè)置上傳請求頭信息
  • :file-list="form.files" 將自定義對象加入到列表中
  • :on-success="handleAvatarSuccess":上傳成功函數(shù)
  • :on-error="handleError":上傳失敗函數(shù)
<el-upload
      ref="upload"
      :auto-upload="false"
      :action=uploadUrl
      :headers="headers"
      :file-list="form.files"
      name="file"
      list-type="picture-card"
      :on-progress='handPic'
      :on-preview="handlePictureCardPreview"
      :on-remove="handleRemove"
      :on-success="handleAvatarSuccess"
      :on-error="handleError"
  >

邏輯實現(xiàn),因為后端返回的是一個圖片地址,這里新增的時候需要拿到圖片上傳結(jié)果,并復(fù)制給對象,進行新增,當點擊提交表單后:調(diào)用submitUpload 自定義函數(shù)。作用是等待上傳結(jié)果。

try {
    await this.submitUpload()
} catch (e) {
    this.$message.warning('請重新上傳圖片~~')
return
}

這里通過 Promise 實現(xiàn)等待效果。通過 this.$refs.upload.submit() 方法進行上傳圖片。

this.uploadPromiseResolve 和 this.uploadPromiseReject 是自定義參數(shù),獲取到當前Promise 的 resolve, reject 引用,從而實現(xiàn)等待,如果沒有這兩個,該函數(shù)將不會等待。當值有引用時,該對象不會被釋放,從而等待。

// 包裝 submit 方法,返回 Promise
async submitUpload() {
  return new Promise((resolve, reject) => {
    this.$refs.upload.submit()
    this.uploadPromiseResolve = resolve
    this.uploadPromiseReject = reject
  })
},

這個時候成功上傳函數(shù)或者失敗函數(shù)會被調(diào)用,成功則把圖片地址復(fù)制給當前表單,然后將響應(yīng)結(jié)果賦值并釋放,一定要釋放。失敗則直接釋放。

//圖片上傳成功
handleAvatarSuccess(response) {
  this.form.img = response.fileName
  this.uploadPromiseResolve(response)
  this.uploadPromiseResolve = null
},
handleError(error) {
  this.uploadPromiseReject(error)
  this.uploadPromiseReject = null
}

回到剛剛的函數(shù)中。整個流程就到完成了。

2. 回顯是如何實現(xiàn)的?

需求是點擊修改,將獲取接口中的圖片地址路徑,進行渲染該圖片。

通過 getDevice 獲取到當前設(shè)備信息,有 img 屬性表示圖片。

接下來,調(diào)用 getImgForObject 函數(shù),傳入圖片,多張圖片由逗號分隔??聪戮唧w實現(xiàn)。

/** 修改按鈕操作 */
async handleUpdate(row) {
  this.reset()
  const id = row.deviceNumber || this.ids
  const {data} = await getDevice(id, this.form.deviceType)
  this.form = data
  this.form.files = await getImgForObject(data.img)
  this.title = '修改設(shè)備'
  this.open = true
}

這里說下邏輯,通過獲取的路徑,去調(diào)用該接口,獲取二進制數(shù)據(jù),將二進制轉(zhuǎn)換成 blob對象,再使用 URL.createObjectURL() 創(chuàng)建當前頁面可訪問的圖片地址。為什么是當前頁面可訪問呢,因為這個是臨時地址,只能被當前會話訪問。最后封裝ELement ui 需要的格式對象返回即可。

// 將二進制數(shù)據(jù)轉(zhuǎn)換成可訪問的Element ui 對象
export async function getImgForObject(imgs) {
    if (imgs) {
        return await Promise.all(
            imgs.split(',').map(async item => {
                const blob = await getImg(item)
                // 將 Blob 對象轉(zhuǎn)換為 File 對象
                const split = item.split('/')
                const file = new File([blob], split[split.length - 1], {type: blob.type})
                // 創(chuàng)建唯一的 uid (可以根據(jù)實際需求生成唯一標識)
                const uid = Date.now()
                // 使用 URL.createObjectURL() 創(chuàng)建可訪問的本地 url
                const fileUrl = URL.createObjectURL(blob)
                // 構(gòu)建 File 對象并返回
                return {
                    name: file.name,
                    percentage: 0,            // 初始上傳進度為 0
                    raw: file,  // Blob 轉(zhuǎn)換為 File
                    size: file.size,          // 文件大小
                    status: 'ready',          // 狀態(tài)設(shè)為 ready
                    uid: uid,                 // 唯一標識符
                    url: fileUrl              // 使用 createObjectURL 生成的本地 URL
                };
            })
        )
    }
}

到此這篇關(guān)于Element plus實現(xiàn)圖片手動上傳與回顯的過程的文章就介紹到這了,更多相關(guān)Element plus圖片上傳與回顯內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue3中keep-alive的使用及注意事項說明

    Vue3中keep-alive的使用及注意事項說明

    這篇文章主要介紹了Vue3中keep-alive的使用及注意事項說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • 在Vue中如何實現(xiàn)打字機的效果

    在Vue中如何實現(xiàn)打字機的效果

    這篇文章主要介紹了在Vue中如何實現(xiàn)打字機的效果,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue雙向數(shù)據(jù)綁定知識點總結(jié)

    vue雙向數(shù)據(jù)綁定知識點總結(jié)

    這篇文章主要介紹了vue雙向數(shù)據(jù)綁定的原理以及知識點總結(jié),并做了代碼實例分析,有需要的朋友參考下。
    2018-04-04
  • Vue2老項目配置ESLint和Prettier完整步驟

    Vue2老項目配置ESLint和Prettier完整步驟

    ESLint是一個靜態(tài)代碼分析工具,用于檢查JavaScript代碼的語法結(jié)構(gòu)和查找程序錯誤,Prettier是一個代碼格式化工具,這篇文章主要給大家介紹了關(guān)于Vue2老項目配置ESLint和Prettier的完整步驟,需要的朋友可以參考下
    2024-08-08
  • 探討Vue.js的組件和模板

    探討Vue.js的組件和模板

    指令是Vue.js中一個重要的特性, 主要提供了一種機制將數(shù)據(jù)的變化映射為DOM行為。下面通過本文給大家分享Vue.js的組件和模板,需要的朋友參考下吧
    2017-10-10
  • vue中ref和$refs獲取元素dom、獲取子組件數(shù)據(jù)與方法調(diào)用示例

    vue中ref和$refs獲取元素dom、獲取子組件數(shù)據(jù)與方法調(diào)用示例

    在Vue3中要獲取子組件的DOM節(jié)點,你可以使用ref來引用子組件,然后通過$refs來訪問子組件的DOM,下面這篇文章主要給大家介紹了關(guān)于vue中ref和$refs獲取元素dom、獲取子組件數(shù)據(jù)與方法調(diào)用的相關(guān)資料,需要的朋友可以參考下
    2024-07-07
  • Vue中使用正則表達式進行文本匹配和處理的方法小結(jié)

    Vue中使用正則表達式進行文本匹配和處理的方法小結(jié)

    正則表達式在Vue中具有廣泛的應(yīng)用場景,包括文本匹配和處理、表單驗證等,通過本文的介紹和示例,希望讀者能更好地理解和應(yīng)用正則表達式在Vue中的使用方法,感興趣的朋友一起看看吧
    2023-11-11
  • Vue中使用Sortable的示例代碼

    Vue中使用Sortable的示例代碼

    這篇文章主要介紹了Vue中使用Sortable的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • Vue使用vux-ui自定義表單驗證遇到的問題及解決方法

    Vue使用vux-ui自定義表單驗證遇到的問題及解決方法

    這篇文章主要介紹了Vue使用vux-ui自定義表單驗證遇到的問題及解決方法,需要的朋友可以參考下
    2018-05-05
  • 詳解vue如何使用rules對表單字段進行校驗

    詳解vue如何使用rules對表單字段進行校驗

    這篇文章主要介紹了詳解vue如何使用rules對表單字段進行校驗,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10

最新評論