溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

element中怎么使用formdata進(jìn)行上傳文件

發(fā)布時間:2023-05-10 15:36:58 來源:億速云 閱讀:115 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“element中怎么使用formdata進(jìn)行上傳文件”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

前言

在使用elementUI文檔的時候,上傳圖片的組件,使用了formdata的方式,第一次使用,在此記錄一下。根據(jù)文檔,就是在上傳的時候,有一個上傳圖片的接口,點(diǎn)擊上傳之后會返回給你一個網(wǎng)絡(luò)路徑,再將網(wǎng)絡(luò)路徑跟表單的其他的信息通過提交接口,提交到后臺即可。

element中怎么使用formdata進(jìn)行上傳文件

一、el-upload中的相關(guān)參數(shù)

<!--上傳圖片-->
          <el-upload
            ref="upload"
            :headers="headers"
            class="upload-demo"
            :class="showUpload === true ? 'show-upload-pic' : ''"
            :limit="5"
            :action="uploadUrl"
            :data="data"
            :file-list="fileList"
            list-type="picture-card"
            :on-success="handleAvatarSuccess"
            :on-preview="handlePictureCardPreview"
            :on-remove="handleRemove"
            :on-change="changeBigImg"
          >
            <i class="el-icon-plus" />
          </el-upload>
          <!--上傳圖片-->

①action必選參數(shù)

action:必選參數(shù),上傳的地址

//上傳的地址,可以根據(jù)不同的環(huán)境配置不同的跳轉(zhuǎn)地址
created() {
    if (process.env.NODE_ENV === "test" || process.env.NODE_ENV === "development") {
      this.uploadUrl = 'https://test.../common/upload_files';
    } else if (process.env.NODE_ENV === "production") {
      this.uploadUrl = 'https://operate.../common/upload_files';
    }
  },

②http-request實(shí)現(xiàn)自定義上傳
但是,如果后臺只給你一個接口,讓你通過formdata來提交。通過查看api發(fā)現(xiàn),還有個方法可以實(shí)現(xiàn)自定義上傳。

http-request:覆蓋默認(rèn)的上傳行為,可以自定義上傳的實(shí)現(xiàn)。

用這個方法之前,我們還要將auto-upload設(shè)置成false.

auto-upload:是否在選取文件后立即進(jìn)行上傳

③headers設(shè)置上傳的請求頭部

headers:設(shè)置上傳的請求頭部

<script>
//可以添加請求的token
import { getToken } from '@/utils/auth'
export default{
	data(){
		return{
			headers:{
				authorization: getToken()
			},
			 data: {
        		projectCode: '',
        		projectVer: '',
        		imageBits: ''
      		},
      		fileList: [],
		}
	},
}
</script>
import Cookies from 'js-cookie'

const TokenKey = 'token'

export function getToken() {
  return Cookies.get(TokenKey)
}

④on-preview點(diǎn)擊文件列表中已上傳的文件時的鉤子

on-preview:點(diǎn)擊文件列表中已上傳的文件時的鉤子

handlePictureCardPreview(file) {
      this.dialogImageUrl = file.url;
      this.dialogUpload = true;
},

⑤on-remove文件列表移除文件時的鉤子

// 刪除文件時,將相關(guān)參數(shù)清空,進(jìn)行處理操作
    handleRemove(file, fileList, response) {
      this.saveParam.urls = '';

      for (let i = 0; i < this.imgArrs.length; i++) {
        if (file.response) {
          if (this.imgArrs[i] === file.response.data[0].imgUrl) {
            this.imgArrs.splice(i, 1);
          }
        } else {
          if (this.imgArrs[i] === file.url) {
            this.imgArrs.splice(i, 1);
          }
        }
      }
      const result = this.imgList.split(",");

      for (let i = 0; i < result.length; i++) {
        if (file.response) {
          if (result[i] === file.response.data[0].imgUrl) {
            result.splice(i, 1);
          }
        } else {
          if (result[i] === file.url) {
            result.splice(i, 1);
          }
        }
      }

      this.imgListCopy = ''; // 重新賦值
      for (let i = 0; i < result.length; i++) {
        this.imgList += result[i] + ",";
        if (result[i] !== '') {
          this.imgListCopy += result[i] + ",";
        }
      }
      this.imgList = this.imgListCopy;

      if (fileList.length < 5) {
        this.showUpload = false;
      }
    },

⑥on-success文件上傳成功時的鉤子

on-success:文件上傳成功時的鉤子

//在文件上傳成功時,將相關(guān)參數(shù)進(jìn)行賦值操作
handleAvatarSuccess(res, fileList) {
      let imgArr = '';

      imgArr = res.data[0].imgUrl;
      this.imgList += imgArr + ",";

      this.imgArrs.push(imgArr);
      if (this.imgArrs.length > 4) {
        this.showUpload = true;
      } else {
        this.showUpload = false;
      }
    },

圖片展示:

element中怎么使用formdata進(jìn)行上傳文件

調(diào)用接口的情況:

element中怎么使用formdata進(jìn)行上傳文件

element中怎么使用formdata進(jìn)行上傳文件

⑦on-change文件狀態(tài)改變時的鉤子,添加文件、上傳成功和上傳失敗時都會被調(diào)用

on-change:文件狀態(tài)改變時的鉤子,添加文件、上傳成功和上傳失敗時都會被調(diào)用

// 上傳圖片的驗(yàn)證
changeBigImg(file, fileList) {
   this.bigFileList = fileList
   this.bigFile = file
}

二、擴(kuò)展&ndash;如何在上傳超過5張圖片后,隱藏上傳按鈕

通過查看代碼,發(fā)現(xiàn)上傳按鈕,是通過.el-upload&ndash;picture-card標(biāo)簽進(jìn)行控制的,那么是不是可以在照片數(shù)量達(dá)到上限時,通過display: none;來控制顯示和隱藏呢?直接對el-upload&ndash;picture-card不好控制,那么就通過判斷數(shù)量,加上動態(tài)類名來控制。

<style>
.show-upload-pic .el-upload--picture-card {
  display: none;
}
</style>
if (fileList.length < 5) {
    this.showUpload = false;
}

if (this.imgArrs.length > 4) {
    this.showUpload = true;
} else {
    this.showUpload = false;
}

if (this.fileList.length >= 5) {
    this.showUpload = true;
} else {
    this.showUpload = false;
}

“element中怎么使用formdata進(jìn)行上傳文件”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI