Vue實(shí)現(xiàn)文件上傳和下載功能
本文實(shí)例為大家分享了Vue實(shí)現(xiàn)文件上傳和下載功能的具體代碼,供大家參考,具體內(nèi)容如下
1、a標(biāo)簽download屬性
在H5中,為a標(biāo)簽新增了一個(gè)download屬性,來(lái)直接文件的下載,文件名就是download屬性文件名。
- download屬性暫時(shí)只支持Google Chrome 和 Mozilla Firefox,其他瀏覽器均不支持該屬性;
- download是H5新增的屬性,H5以前沒(méi)有該屬性;
2、URL.createObjectURL
URL.createObjectURL()方法會(huì)根據(jù)傳入的參數(shù)創(chuàng)建一個(gè)指向該參數(shù)對(duì)象的URL,這個(gè)URL的生命僅存在于它被創(chuàng)建的這個(gè)文檔里,新的對(duì)象URL指向執(zhí)行的File對(duì)象或者是Blob對(duì)象。
File對(duì)象,就是一個(gè)文件,比如我用input type="file"標(biāo)簽來(lái)上傳文件,那么里面的每個(gè)文件都是一個(gè)File對(duì)象。
Blob對(duì)象,就是二進(jìn)制數(shù)據(jù),比如通過(guò)new Blob()創(chuàng)建的對(duì)象就是Blob對(duì)象,又比如在XMLHttpRequest里,如果指定responseType為blob,那么得到的返回值也是一個(gè)blob對(duì)象。
let URL = window.URL || window.webkitURL; let downloadUrl = URL.createObjectURL(blob || file);
3、URL.revokeObjectURL
URL.revokeObjectURL()方法會(huì)釋放一個(gè)通過(guò)URL.createObjectURL()創(chuàng)建的對(duì)象URL,如果不再需要這個(gè)對(duì)象,就要釋放它,被釋放掉以后,這個(gè)對(duì)象URL就不再指向指定的文件了。
downloadUrl && URL.revokeObjectURL(downloadUrl);
4、Vue.js上傳和下載文件
<template> <div class="btn-box"> <h3>文件上傳:</h3> <input class="file-input" type="file" @change="getFile($event)" /> <el-button type="primary" @click="upload">上傳文件(POST)</el-button> <h3>文件下載:</h3> <el-button type="primary" @click="downloadLink">下載帶鏈接文件(window.open)</el-button> <el-button type="primary" @click="downloadBlobByGet">二進(jìn)制流下載(GET)</el-button> <el-button type="primary" @click="downloadBlobByPost">二進(jìn)制流下載(POST)</el-button> </div> </template> <script> import axios from "axios" export default { name: "attendPoint", data() { return {, file: null, fileName: "test.xlsx" } }, methods: { // 選取文件 getFile(event) { this.file = event.target.files[0]; }, // 上傳文件(POST) upload() { let url = "http://localhost:3000/upload/test"; let formData = new FormData(); formData.append("name", "zhangsan"); formData.append("age", "18"); formData.append("file", this.file); let config = { headers: { "Content-Type": "multipart/form-data" } } axios.post(url, formData, config).then((res) => { this.fileName = res.data.downloadUrl; this.$message.success("上傳成功!"); }).catch(() => { this.$message.error("請(qǐng)先上傳文件!"); }) }, // 下載帶鏈接文件(window.open) downloadLink() { if (this.fileName) { window.open("http://localhost:3000/download/test?fileName=" + this.fileName); } }, // 二進(jìn)制流下載(GET) async downloadBlobByGet() { let urlGet = "http://localhost:3000/download/test?fileName=" + this.fileName; let fileData = await axios.get(urlGet, { responseType: "blob" }); let URL = window.URL || window.webkitURL; let downloadUrl = URL.createObjectURL(fileData.data); let a = document.createElement("a"); a.href = downloadUrl; a.download = this.fileName;//下載后文件名 a.click(); a = null; downloadUrl && URL.revokeObjectURL(downloadUrl); }, // 二進(jìn)制流下載(POST) async downloadBlobByPost() { let urlPost = "http://localhost:3000/download/post/test"; let fileData = await axios({ method: "post", url: urlPost, // 請(qǐng)求地址 data: { fileName: this.fileName }, // 參數(shù) responseType: "blob" // 表明返回服務(wù)器返回的數(shù)據(jù)類型 }) let URL = window.URL || window.webkitURL; let downloadUrl = URL.createObjectURL(fileData.data); let a = document.createElement("a"); a.download = this.fileName; a.href = downloadUrl; a.click(); a = null; downloadUrl && URL.revokeObjectURL(downloadUrl); }, }, } </script> <style scoped> .btn-box { padding: 20px; } .el-button, input { max-width: fit-content; display: block; margin: 20px; } </style>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue scrollBehavior 滾動(dòng)行為實(shí)現(xiàn)后退頁(yè)面顯示在上次瀏覽的位置
這篇文章主要介紹了Vue scrollBehavior 滾動(dòng)行為實(shí)現(xiàn)后退頁(yè)面顯示在上次瀏覽的位置,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05VSCode創(chuàng)建Vue項(xiàng)目的完整步驟教程
Vue是一個(gè)輕量級(jí)、漸進(jìn)式的Javascript框架,如果想要要開(kāi)發(fā)全新的Vue項(xiàng)目,建議項(xiàng)目構(gòu)建工具vue-cli,下面這篇文章主要給大家介紹了關(guān)于VSCode創(chuàng)建Vue項(xiàng)目的完整步驟,需要的朋友可以參考下2022-06-06使用vue實(shí)現(xiàn)多規(guī)格選擇實(shí)例(SKU)
這篇文章主要介紹了使用vue實(shí)現(xiàn)多規(guī)格選擇實(shí)例(SKU),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08element-plus?el-form表單驗(yàn)證使用方法以及注意事項(xiàng)
這篇文章主要給大家介紹了關(guān)于element-plus?el-form表單驗(yàn)證使用方法以及注意事項(xiàng)的相關(guān)資料,表單驗(yàn)證能通過(guò)設(shè)置驗(yàn)證規(guī)則驗(yàn)證用戶的輸入,并對(duì)不規(guī)范的輸入做出對(duì)應(yīng)提示,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12ElementUI?$notify通知方法中渲染自定義組件實(shí)現(xiàn)
這篇文章主要為大家介紹了ElementUI?$notify通知方法中渲染自定義組件實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06vue 實(shí)現(xiàn)Web端的定位功能 獲取經(jīng)緯度
這篇文章主要介紹了vue 實(shí)現(xiàn)Web端的定位功能獲取經(jīng)緯度,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08Vue腳手架配置代理服務(wù)器的兩種方式(小結(jié))
本文主要介紹了Vue腳手架配置代理服務(wù)器的兩種方式(小結(jié)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01vue+node 實(shí)現(xiàn)視頻在線播放的實(shí)例代碼
這篇文章主要介紹了vue+node 實(shí)現(xiàn)視頻在線播放的實(shí)例代碼,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10echarts 使用formatter 修改鼠標(biāo)懸浮事件信息操作
這篇文章主要介紹了echarts 使用formatter 修改鼠標(biāo)懸浮事件信息操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07Vue計(jì)算屬性中reduce方法實(shí)現(xiàn)遍歷方式
這篇文章主要介紹了Vue計(jì)算屬性中reduce方法實(shí)現(xiàn)遍歷方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03