小鱼儿心语:你的假装努力,欺骗的只有你自己,永远不要用战术上的勤奋,来掩饰战略上的懒惰。
一、下载普通文件
download1(res) {
// res为返回的流地址
// 下载文件
const link = document.createElement('a'); // 创建元素
let blob = new Blob([res]);
link.style.display = 'none';
link.href = URL.createObjectURL(blob);
link.setAttribute('download', '应急工作组成员导入模板.xlsx') // 为下载后的文件命名
document.body.appendChild(link)
link.click(); // 点击下载
document.body.removeChild(link) // 下载完成后移除元素
window.URL.revokeObjectURL(link.href) // 释放blob对象
},
二、下载pdf文件
tapbaogao() {
// 接口请求
exportPdf().then(res => {
console.log(res,'返回的流地址')
const url = window.URL.createObjectURL(new Blob([res], { type: `application/pdf` }));
const link = document.createElement('a');
link.href = url;
link.setAttribute('download', '评估报告.pdf'); // 设置下载的文件名
document.body.appendChild(link); // 需要添加到文档中
link.click(); // 触发下载
// document.body.removeChild(link); // 下载后移除链接
});
},
三、下载压缩包文件
import axios from 'axios'
import { getToken } from '@/utils/auth'
const mimeMap = {
xlsx: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
zip: 'application/zip'
}
const baseUrl = process.env.VUE_APP_BASE_API
export function downLoadZip(str, filename) {
var url = baseUrl + str
axios({
method: 'get',
url: url,
responseType: 'blob',
headers: { 'token': 'Bearer ' + getToken() }
}).then(res => {
resolveBlob(res, mimeMap.zip)
})
}
/**
* 解析blob响应内容并下载
* @param {*} res blob响应内容
* @param {String} mimeType MIME类型
*/
export function resolveBlob(res, mimeType) {
const aLink = document.createElement('a')
var blob = new Blob([res.data], { type: mimeType })
// //从response的headers中获取filename, 后端response.setHeader("Content-disposition", "attachment; filename=xxxx.docx") 设置的文件名;
var patt = new RegExp('filename=([^;]+\\.[^\\.;]+);*')
var contentDisposition = decodeURI(res.headers['content-disposition'])
var result = patt.exec(contentDisposition)
var fileName = result[1]
fileName = fileName.replace(/\"/g, '')
aLink.style.display = 'none'
aLink.href = URL.createObjectURL(blob)
aLink.setAttribute('download', fileName) // 设置下载文件名称
document.body.appendChild(aLink)
aLink.click()
URL.revokeObjectURL(aLink.href);//清除引用
document.body.removeChild(aLink);
}
四、通用的下载方法
// 通用下载方法
download(fileName) {
window.location.href = baseURL + "/common/download?fileName=" + encodeURI(fileName) + "&delete=" + true;
}
/** 下载模板操作 */
importTemplate() {
importTemplate().then(response => {
this.download(response.msg)
})
},