×

Vue每日一学:分享“文件上传和下载”的代码片段

作者:Terry2021.10.25来源:Web前端之家浏览:5165评论:0
关键词:vuejs

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);


您的支持是我们创作的动力!
温馨提示:本文作者系Terry ,经Web前端之家编辑修改或补充,转载请注明出处和本文链接:
https://jiangweishan.com/article/vuejs20211025a2.html

网友评论文明上网理性发言 已有0人参与

发表评论: