本文实例为大家分享了Vue实现文件上传和下载功能的具体代码,供大家参考,具体内容如下
1、a标签download属性
在H5中,为a标签新增了一个download属性,来直接文件的下载,文件名就是download属性文件名。
- download属性暂时只支持Google Chrome 和 Mozilla Firefox,其他浏览器均不支持该属性;
- download是H5新增的属性,H5以前没有该属性;
2、URL.createObjectURL
URL.createObjectURL()方法会根据传入的参数创建一个指向该参数对象的URL,这个URL的生命仅存在于它被创建的这个文档里,新的对象URL指向执行的File对象或者是Blob对象。
File对象,就是一个文件,比如我用input type="file"标签来上传文件,那么里面的每个文件都是一个File对象。
Blob对象,就是二进制数据,比如通过new Blob()创建的对象就是Blob对象,又比如在XMLHttpRequest里,如果指定responseType为blob,那么得到的返回值也是一个blob对象。
let URL = window.URL || window.webkitURL;
let downloadUrl = URL.createObjectURL(blob || file);
3、URL.revokeObjectURL
URL.revokeObjectURL()方法会释放一个通过URL.createObjectURL()创建的对象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">二进制流下载(GET)</el-button>
<el-button type="primary" @click="downloadBlobByPost">二进制流下载(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);
}
},
// 二进制流下载(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);
},
// 二进制流下载(POST)
async downloadBlobByPost() {
let urlPost = "http://localhost:3000/download/post/test";
let fileData = await axios({
method: "post",
url: urlPost, // 请求地址
data: { fileName: this.fileName }, // 参数
responseType: "blob" // 表明返回服务器返回的数据类型
})
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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。