Vue實現文件上傳和下載功能
本文實例為大傢分享瞭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>
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。
推薦閱讀:
- vue如何實現二進制流文件導出excel
- 一文詳解如何根據後端返回的url下載json文件
- vue中如何下載excel流文件及設置下載文件名
- 前端使用axios實現下載文件功能的詳細過程
- vue導出excel文件流中文亂碼問題及解決