前端axios下载excel文件(二进制)的处理方法

需求:通过后端接口下载excel文件,后端没有文件地址,返回二进制流文件

实现:axios(ajax类似)

主要代码

axios:设置返回数据格式为blob或者arraybuffer

如:

rush:js;"> var instance = axios.creat({ ... //一些配置 responseType: 'blob',//返回数据的格式,可选值为arraybuffer,blob,document,json,text,stream,认值为json })

请求时的处理:

{   //这里res.data是返回的blob对象   var blob = new Blob([res.data],{type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8'}); //application/vnd.openxmlformats-officedocument.spreadsheetml.sheet这里表示xlsx类型   var downloadElement = document.createElement('a');   var href = window.URL.createObjectURL(blob); //创建下载的链接   downloadElement.href = href;   downloadElement.download = 'xxx.xlsx'; //下载后文件名   document.body.appendChild(downloadElement);   downloadElement.click(); //点击下载   document.body.removeChild(downloadElement); //下载完成移除元素   window.URL.revokeObjectURL(href); //释放掉blob对象  })

总结

以上所述是小编给大家介绍的前端axios下载excel文件(二进制)的处理方法。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...