vue下载后台传过来的流文件(如excel)并设置下载文件名

2021-01-19  本文已影响0人  FSYu

这里介绍两种方法,使用 Blob对象 和 使用 js-file-download

这两种方法下载的文件都不会乱码,但是 不管使用哪种方法,发送请求时都要设置 responseType

方法一:使用Blob对象

Blob对象表示一个不可变、原始数据的类文件对象。Blob 表示的不一定是JavaScript原生格式的数据。File接口基于Blob,继承了blob的功能并将其扩展使其支持用户系统上的文件。

一、Blob() 构造函数

摘自:Blob() 构造函数

语法

var aBlob = new Blob( array, options );

参数

二、URL对象

通过创建URL对象指定文件的下载链接。

// 创建新的URL表示指定的File对象或者Blob对象。
let objectURL = window.URL.createObjectURL(blob); 
window.URL.revokeObjectURL(objectURL); // 释放内存

在每次调用createObjectURL()方法时,都会创建一个新的 URL 对象,即使你已经用相同的对象作为参数创建过。当不再需要这些 URL 对象时,每个对象必须通过调用 URL.revokeObjectURL()方法来释放。浏览器会在文档退出的时候自动释放它们,但是为了获得最佳性能和内存使用状况,你应该在安全的时机主动释放掉它们。

三、利用a标签自定义文件名

const link = document.createElement('a'); // 生成一个a标签。
link.href = window.URL.createObjectURL(blob); // href属性指定下载链接
link.download = fileName; // dowload属性指定文件名
link.click(); // click()事件触发下载

download 属性设置文件名时,可以直接设置扩展名。如果没有设置,则浏览器将自动检测正确的文件扩展名并添加到文件 。

四:主要完整代码

方法二:使用 js-file-download

转载:https://segmentfault.com/a/1190000020540788

上一篇下一篇

猜你喜欢

热点阅读