浏览器自动下载后端返回的文件流

文章描述了一个前端实现文件下载的流程,通过点击页面按钮触发download方法,该方法调用axios接口获取文件流。利用接口返回的content-disposition头信息设置文件名,将文件流转换为Blob对象,创建并模拟点击a标签来触发浏览器下载。整个过程涉及HTTP响应类型设置为blob。

页面效果

在这里插入图片描述

页面点击下载方法

download(row) {
	// 调用接口获取文件流
	const res = newyqaxios.downloadFile({ywh:row.ywh})
	//处理文件流设置浏览器下载路径
	let fileName = res.headers["content-disposition"].split("filename=")[1]
	let fileHref = window.URL.createObjectURL(new Blob([res.data]))
	// 模拟点击下载
	var downloadElement = document.createElement("a")
	downloadElement.href = fileHref
	downloadElement.download = decodeURIComponent(fileName)
	document.body.appendChild(downloadElement)
	downloadElement.click()
	document.body.removeChild(downloadElement)
	window.URL.revokeObjectURL(fileHref)
}

调用接口获取文件流

//归档办件下载附件材料
    downloadFile(params) {
        return axios.request({
            url: MICRO_CONFIG.homestead_approve + 'zhgl/bjdowmload/downloadFile',
            method: 'get',
            params: params,
            responseType: 'blob'//注意这里下载获取文件流type
        })
    },
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值