前台请求数据:
url: '/app/downloadApp', method: 'get', responseType: 'blob', params: data
设置接收参数格式为responseType: ‘blob',
downloadFile(res, fileName) { if (!res) { return } if (window.navigator.msSaveBlob) { // IE以及IE内核的浏览器 try { window.navigator.msSaveBlob(res, fileName) // res为接口返回数据,这里请求的时候已经处理了,如果没处理需要在此之前自行处理var data = new Blob([res.data]) 注意这里需要是数组形式的,fileName就是下载之后的文件名 // window.navigator.msSaveOrOpenBlob(res, fileName); //此方法类似上面的方法,区别可自行百度 } catch (e) { console.log(e) } } else { let url = window.URL.createObjectURL(new Blob([res])) let link = document.createElement('a') link.style.display = 'none' link.href = url link.setAttribute('download', fileName)// 文件名 document.body.appendChild(link) link.click() document.body.removeChild(link) // 下载完成移除元素 window.URL.revokeObjectURL(url) // 释放掉blob对象 } }, download(){ var data = { appId:this.appId } downloadAppAjax(data).then(res => { const filename = decodeURI(res.headers['content-disposition'].split(';')[1].split('=')[1]); console.log(filename) this.downloadFile(res.data,filename) }) }
这里的downloadAppAjax调用后台接口,请求数据,获取后台返回的数据没有文件名,最后发现在header Content-Disposition属性里 attachment;filename=app.jpg
所以我们要实现下载自动重命名就需要拿出filename,这里我们使用decodeURI对Content-Disposition属性值进行解码,拿到filename:
decodeURI(res.headers['content-disposition'].split(';')[1].split('=')[1]);
拿到文件流和文件名后 接收文件流并创建地址
let url =window.URL.createObjectURL(new Blob([res]))
接着利用a标签进行下载即可。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“Javascript前端下载后台传来的文件流代码实例”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
20240525
20240525
- [天乐AA天碟]UncompressedWorldVol.1《无压缩世界1:纯净原音》[24-96]FLAC
- 陈琳.1994-请别再说爱我(TP版)【国际文化】【WAV+CUE】
- 吴倩莲.1996-回家【EMI百代】【WAV+CUE】
- 群星.1989-宝丽金浪漫舞曲超白金【宝丽金】【WAV+CUE】
- 许茹芸《高端定制音响专业示范碟 我为芸开》[WAV+CUE][600MB]
- 费翔-《献给最挑剔的耳朵 精挑细选十八首 HQCD》[WAV+CUE][650MB]
- 《邓丽君 70周年特集4CD香港版》[WAV+CUE][1.7GB]
- 减压睡眠音乐《听着音乐SPA入眠2CD》HQ金碟[DTS+WAV]
- 群星《2016最受欢迎女歌手2CD》DTS-ES[WAV分轨]
- 24Bit极品发烧人声测试《男人咖啡·HIFI男声2CD》DTS[WAV/分轨]
- 陈震.1994-不要让我再爱你再想你【蓝与白】【WAV+CUE】
- 群星.2012-赵季平创作歌曲精选4CD【上海音乐出版社】【WAV+CUE】
- 梁汉文.1998-星火【华星】【WAV+CUE】
- AhNeeMah阿尼玛《NativeSpirit原始灵魂》(2009)示范碟DTS-NRG
- 群星1992-卡拉屋企[香港首版][WAV+CUE]