温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Vue如何实现文件上传和下载功能

发布时间:2021-09-24 15:30:37 来源:亿速云 阅读:1689 作者:小新 栏目:开发技术

这篇文章主要介绍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">         <h4>文件上传:</h4>         <input class="file-input" type="file" @change="getFile($event)" />         <el-button type="primary" @click="upload">上传文件(POST)</el-button>         <h4>文件下载:</h4>         <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>

以上是“Vue如何实现文件上传和下载功能”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue
AI