Vue每日一学:分享“文件上传和下载”的代码片段。
<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>
里面有几个属性说明下:
download
在H5中,为a标签新增了一个download属性,来直接文件的下载,文件名就是download属性文件名。
download属性暂时只支持Google Chrome 和 Mozilla Firefox,其他浏览器均不支持该属性;
download是H5新增的属性,H5以前没有该属性;
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);
URL.revokeObjectURL
URL.revokeObjectURL()方法会释放一个通过URL.createObjectURL()创建的对象URL,如果不再需要这个对象,就要释放它,被释放掉以后,这个对象URL就不再指向指定的文件了。
downloadUrl && URL.revokeObjectURL(downloadUrl);
网友评论文明上网理性发言 已有0人参与
发表评论: