您好,登錄后才能下訂單哦!
這篇文章主要介紹了vue elementUI怎么處理文件批量上傳的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇vue 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 }?`); }
批量手動上傳文件,和表單數據一起提交
multiple
:auto-upload = "false"
:file-list = "fileList"
:on-change = "selectFile"
(里面是把上傳的fileList傳給自定義的 this.fileList)
a.定義FormData,將表單數據和文件填充到FormData里面
b.自定義請求頭部,Content-type:‘multipart/form-data’
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怎么處理文件批量上傳”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。