Vue實現(xiàn)文件上傳和下載功能
本文實例為大家分享了Vue實現(xiàn)文件上傳和下載功能的具體代碼,供大家參考,具體內(nèi)容如下
1、a標(biāo)簽download屬性
在H5中,為a標(biāo)簽新增了一個download屬性,來直接文件的下載,文件名就是download屬性文件名。
- download屬性暫時只支持Google Chrome 和 Mozilla Firefox,其他瀏覽器均不支持該屬性;
- download是H5新增的屬性,H5以前沒有該屬性;
2、URL.createObjectURL
URL.createObjectURL()方法會根據(jù)傳入的參數(shù)創(chuàng)建一個指向該參數(shù)對象的URL,這個URL的生命僅存在于它被創(chuàng)建的這個文檔里,新的對象URL指向執(zhí)行的File對象或者是Blob對象。
File對象,就是一個文件,比如我用input type="file"標(biāo)簽來上傳文件,那么里面的每個文件都是一個File對象。
Blob對象,就是二進(jìn)制數(shù)據(jù),比如通過new Blob()創(chuàng)建的對象就是Blob對象,又比如在XMLHttpRequest里,如果指定responseType為blob,那么得到的返回值也是一個blob對象。
let URL = window.URL || window.webkitURL; let downloadUrl = URL.createObjectURL(blob || file);
3、URL.revokeObjectURL
URL.revokeObjectURL()方法會釋放一個通過URL.createObjectURL()創(chuàng)建的對象URL,如果不再需要這個對象,就要釋放它,被釋放掉以后,這個對象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("請先上傳文件!");
})
},
// 下載帶鏈接文件(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, // 請求地址
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>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue中使用Echarts?map圖實現(xiàn)下鉆至縣級的思路詳解
這篇文章主要介紹了vue中使用Echarts?map圖實現(xiàn)下鉆至縣級,需要注意的是,因為我是直接從?vue-cli2?直接跳到?vue-cli4?,還奇怪怎么讀取不到JSON,查找后才知道?vue-cli3?往后的項目基礎(chǔ)架構(gòu)對比舊版本有些區(qū)別,感興趣的朋友跟隨小編一起看看吧2022-01-01
vue+elementui(對話框中form表單的reset問題)
這篇文章主要介紹了vue+elementui(對話框中form表單的reset問題),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05
Vue2.0基于vue-cli+webpack Vuex的用法(實例講解)
下面小編就為大家?guī)硪黄猇ue2.0基于vue-cli+webpack Vuex的用法(實例講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09
vue3點擊出現(xiàn)彈窗后背景變暗且不可操作的實現(xiàn)代碼
這篇文章主要介紹了vue3點擊出現(xiàn)彈窗后背景變暗且不可操作的實現(xiàn)代碼,本文通過實例代碼圖文相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08
VUE子組件向父組件傳值詳解(含傳多值及添加額外參數(shù)場景)
這篇文章主要給大家介紹了關(guān)于VUE子組件向父組件傳值(含傳多值及添加額外參數(shù)場景)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
vue使用百度地圖報錯BMap?is?not?defined問題及解決
這篇文章主要介紹了vue使用百度地圖報錯BMap?is?not?defined問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
vue3如何解決各場景l(fā)oading過度(避免白屏尷尬!)
在開發(fā)的過程中點擊提交按鈕,或者是一些其它場景總會遇到loading加載,下面這篇文章主要給大家介紹了關(guān)于vue3如何解決各場景l(fā)oading過度的相關(guān)資料,避免白屏尷尬,需要的朋友可以參考下2023-03-03

