亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

vue?elementUI怎么處理文件批量上傳

發布時間:2022-04-27 12:43:51 來源:億速云 閱讀:918 作者:iii 欄目:開發技術

這篇文章主要介紹了vue elementUI怎么處理文件批量上傳的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇vue elementUI怎么處理文件批量上傳文章都會有所收獲,下面我們一起來看看吧。

elementUI 如何處理文件批量上傳

問題

elementUI的Upload上傳組件,通過設置multiple為true,就可以實現多選文件;但是在處理的時候還是一個一個傳上去。目前需要在所有文件上傳后,將某幾個上傳錯誤的結果拼接起來做一次提醒

解決

this.$refs.upload.uploadFiles

該屬性可以獲取上傳的文件相關信息,包括上傳后后端返回的response

html

el-upload
  ref='upload'
  class="upload-demo"
  action="https://jsonplaceholder.typicode.com/posts/"
  :on-preview="handlePreview"
  :on-remove="handleRemove"
  :before-remove="beforeRemove"
  multiple
  :on-success='upLoadSuccess'
  accept=".doc,.docx">
  <el-button size="small" type="primary">點擊上傳</el-button>
  <div slot="tip" class="el-upload__tip">只能上傳doc/docx文件</div>
</el-upload>

方法處理 

upLoadSuccess(response, file, fileList) {
    if (this.$refs.upload.uploadFiles) {
        let length = this.$refs.upload.uploadFiles.length
        this.UpLoadFilesLength ++  // 全局變量,用來計算upLoadSuccess方法調用次數
        if (this.UpLoadFilesLength == length) {
            this.UpLoadAllFilesLength = 0  // 如果方法調用的次數和文件列表的長度相同,說明所有文件都上傳完畢,將該全局變量置0
            this.resErrorStr() // 該函數處理每個文件上傳錯誤情況下response拼接
        }
    }
},
resErrorStr() {
    if (this.$refs.upload.uploadFiles) { // 如果存在這個值
        let filesList = this.$refs.upload.uploadFiles.slice()
        let UpLoadAllErrorStr = '' // 錯誤信息拼接變量
        for (let i = 0; i < filesList.length; i++) {
            if (filesList[i].response) {
                if (filesList[i].response.code != 200) { // 如果該文件上傳后返回的狀態值不是200,則說明該文件上傳錯誤
                    UpLoadAllErrorStr += `${filesList[i].response.message}<br/>`
                }
            }
        }
        if (!UpLoadAllErrorStr) {
            this.$message({ type: 'success', message: '上傳文件成功!' });
        } else {
            this.$message({
                type: 'error',
                dangerouslyUseHTMLString: true,
                message: UpLoadAllErrorStr
            });
        }
        this.$refs.uploadAll.uploadFiles = [] // 調用完成之后將值置空,防止再次上傳將上次結果也記錄下來
    }
},
handleRemove(file, fileList) {
    console.log(file, fileList);
},
handlePreview(file) {
    console.log(file);
},
beforeRemove(file, fileList) {
    return this.$confirm(`確定移除 ${ file.name }?`);
}

elementUI批量上傳下載注意事項

批量手動上傳文件,和表單數據一起提交

在el-upload組件關鍵的鉤子,其它省略

  • multiple

  • :auto-upload = "false"

  • :file-list = "fileList"

  • :on-change = "selectFile"  (里面是把上傳的fileList傳給自定義的  this.fileList)

點擊上傳,將多個文件和表單數據一起上傳

a.定義FormData,將表單數據和文件填充到FormData里面

b.自定義請求頭部,Content-type:&lsquo;multipart/form-data&rsquo;

let formData = new FormData()
for(let key in data){
    if(data[key]){
      formData.append(key,data[key])
    } 
}
this.fileList.forEach((element,i) =>{
  formData.append('fileList',element.raw)
})
let rs = await axios({
  method:'post',
  url: cfg.uploadURL + '/sp/addSp',
  data: formData,
  headers:{
    'Content-type':'multipart/form-data'
  } 
})

表格中上傳文件中,組件鉤子函數自帶參數

<el-upload
  class="upload-demo"
  action="https://jsonplaceholder.typicode.com/posts/"
  :on-preview="handlePreview"
  :on-remove="handleRemove"
  :before-remove="(file,fileList)=>{
     return beforeRemove(file,fileList,scope.$index)
  }"
  multiple
  :limit="3"
  :on-exceed="handleExceed"
  :file-list="fileList">
  <el-button size="small" type="primary">點擊上傳</el-button>
  <div slot="tip" class="el-upload__tip">只能上傳jpg/png文件,且不超過500kb</div>
</el-upload>
beforeRemove(file,fileList,index){
    console.log(index)
}

批量下載(后臺不返回壓縮包,前端就一個個下載了)

download(val){
  let vals = val.split(',') //后臺返回的文件標識符數組
  vals.forEach((element) =>{
    const iframe = document.createElement("iframe");
    iframe.style.display = "none";
    iframe.style.height = 0;
    iframe.src = cfg.baseURL+'下載路徑'+element; 
    document.body.appendChild(iframe); 
    setTimeout(()=>{
      iframe.remove();
    }, 1000)
  })
}

關于“vue elementUI怎么處理文件批量上傳”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“vue elementUI怎么處理文件批量上傳”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兰西县| 敦煌市| 新泰市| 云林县| 米脂县| 四川省| 金门县| 阿拉尔市| 英山县| 盱眙县| 策勒县| 益阳市| 海城市| 涪陵区| 桃园县| 临武县| 蓝田县| 太保市| 乌鲁木齐县| 定安县| 海原县| 稷山县| 虎林市| 兴国县| 贡嘎县| 巫山县| 卢氏县| 平原县| 星座| 离岛区| 和硕县| 水城县| 金阳县| 分宜县| 林甸县| 八宿县| 兴国县| 民和| 永胜县| 阜阳市| 潞城市|