vue使用blob下载文件遇到的问题小结

2024-03-01 0 344

Blob 对象表示一个不可变、原始数据的类文件对象。它的数据可以按文本或二进制的格式进行读取。

在项目中遇到需求,需要将后端返回的二进制流下载成 excel 表格形式,首先,先写一个方法用来下载

export function fileDownload(res) {
let blob = new Blob([res.data], {
type: res.data.type,
})
let downloadElement = document.createElement(\’a\’)
let href = window.URL.createObjectURL(blob) //创建下载链接
let fileName = res.headers[\’content-disposition\’]
? res.headers[\’content-disposition\’].split(\’attachment;filename=\’)[1]
: new Date().getTime()
downloadElement.href = href
// window.open(downloadElement.href)
downloadElement.download = decodeURIComponent(fileName) //解码
document.body.appendChild(downloadElement)
downloadElement.click()
document.body.removeChild(downloadElement)
window.URL.revokeObjectURL(href) //释放掉blob对象
}

当然,也可以使用自定义的文件名,自己传递一个文件名即可

export function downloadFile(res, fileName) {
const blob = new Blob([res.data], { type: res.data.type })
let dom = document.createElement(\’a\’)
let url = window.URL.createObjectURL(blob)
dom.href = url
dom.download = decodeURI(fileName)
dom.style.display = \’none\’
document.body.appendChild(dom)
dom.click()
dom.parentNode.removeChild(dom)
window.URL.revokeObjectURL(url)
}

需要注意的是,要记得在下载接口的地方加上responseType: 'blob',

vue使用blob下载文件遇到的问题小结

切记,一定要加上responseType: 'blob', 否则下载的会乱码甚至读取不出来

加上之后,在需要使用的地方使用即可

async handleSubmit() {
if (this.form.pushDepartment.length === 0) {
this.$message.warning(`推送部门不能为空`)
return false
}
// 导出excel表格
let params = {
healthCodeAlarmIds: [],
sendDepartment: [],
}
this.selectData.forEach((item) => {
let id = parseInt(item.id)
params.healthCodeAlarmIds.push(id)
})
params.sendDepartment = this.form.pushDepartment
let res = await exportInfo({ …params })
// console.log(\’res\’, res)
fileDownload(res)
// downloadFile(res, \’yj.xlsx\’)
},

到此这篇关于vue使用blob下载文件遇到的问题的文章就介绍到这了,更多相关vueblob下载文件内容请搜索悠久资源网以前的文章或继续浏览下面的相关文章希望大家以后多多支持悠久资源网!

您可能感兴趣的文章:

  • vue从后端获取到文件的 url 地址及前端根据 url 地址下载文件的实现思路
  • vue3点击按钮下载文件功能的代码实现
  • Vue项目el-upload 上传文件及回显照片和下载文件功能实现
  • vue进行下载与处理二进制流文件的方法详解
  • vue实现批量下载文件
  • vue中下载文件后无法打开的坑及解决

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 JavaScript vue使用blob下载文件遇到的问题小结 https://www.u-9.cn/biancheng/javascript/182043.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务