Javascript前端下载后台传来的文件流代码实例


Posted in Javascript onAugust 18, 2020

前台请求数据:

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标签进行下载即可。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery Ajax请求状态管理器打包
May 03 Javascript
javascript数字格式化通用类 accounting.js使用
Aug 24 Javascript
jquery实现table鼠标经过变色代码
Sep 25 Javascript
js中数组排序sort方法的原理分析
Nov 20 Javascript
JavaScript中reduce()方法的使用详解
Jun 09 Javascript
node.js cookie-parser 中间件介绍
Jun 06 Javascript
Angularjs中ng-repeat-start与ng-repeat-end的用法实例介绍
Dec 31 Javascript
jQuery实现的动态文字变化输出效果示例【附演示与demo源码下载】
Mar 24 jQuery
微信小程序实现人脸识别
May 25 Javascript
详解element-ui中el-select的默认选择项问题
Aug 02 Javascript
vue实现虚拟列表功能的代码
Jul 28 Javascript
解决vue打包报错Unexpected token: punc的问题
Oct 24 Javascript
Vue-cli assets SubDirectory及PublicPath区别详解
Aug 18 #Javascript
JavaScript语句错误throw、try及catch实例解析
Aug 18 #Javascript
JavaScript中交换值的10种方法总结
Aug 18 #Javascript
js+css3实现炫酷时钟
Aug 18 #Javascript
纯js+css实现在线时钟
Aug 18 #Javascript
three.js 利用uv和ThreeBSP制作一个快递柜功能
Aug 18 #Javascript
js+css实现扇形导航效果
Aug 18 #Javascript
You might like
php使用session二维数组实例
2014/11/06 PHP
PHP动态页生成静态页的3种常用方法
2014/11/13 PHP
PHP之浮点数计算比较以及取整数不准确的解决办法
2015/07/29 PHP
PHP中的表达式简述
2016/05/29 PHP
Centos PHP 扩展Xchche的安装教程
2016/07/09 PHP
javascript实现的网页局布刷新效果
2008/12/01 Javascript
jquery实现鼠标拖动图片效果示例代码
2014/01/09 Javascript
js实现日期级联效果
2014/01/23 Javascript
如何设置一定时间内只能发送一次请求
2014/02/28 Javascript
JS+CSS实现简易的滑动门效果代码
2015/09/24 Javascript
JS模态窗口返回值兼容问题的完美解决方法
2016/05/28 Javascript
设置jquery UI 控件的大小方法
2016/12/12 Javascript
原生JS控制多个滚动条同步跟随滚动效果
2017/12/22 Javascript
微信小程序实现自定义加载图标功能
2018/07/19 Javascript
vue vue-Router默认hash模式修改为history需要做的修改详解
2018/09/13 Javascript
JavaScript 面向对象基础简单示例
2019/10/02 Javascript
[43:43]完美世界DOTA2联赛PWL S2 LBZS vs Forest 第三场 11.29
2020/12/02 DOTA
Android模拟器无法启动,报错:Cannot set up guest memory ‘android_arm’ Invalid argument的解决方法
2016/07/01 Python
python利用matplotlib库绘制饼图的方法示例
2016/12/18 Python
python 全文检索引擎详解
2017/04/25 Python
Flask框架各种常见装饰器示例
2018/07/17 Python
Python编程图形库之Pillow使用方法讲解
2018/12/28 Python
Python操作SQLite数据库过程解析
2019/09/02 Python
python wxpython 实现界面跳转功能
2019/12/17 Python
pyqt5数据库使用详细教程(打包解决方案)
2020/03/25 Python
Django 解决distinct无法去除重复数据的问题
2020/05/20 Python
Python图像处理二值化方法实例汇总
2020/07/24 Python
松下电器美国官方商店:Panasonic美国
2016/10/14 全球购物
美国购买当代和现代家具网站:MODTEMPO
2018/07/20 全球购物
年终自我鉴定
2013/10/09 职场文书
食品营养与检测应届生求职信
2013/11/08 职场文书
质检部经理岗位职责
2014/02/19 职场文书
新郎结婚保证书
2015/02/26 职场文书
调任通知
2015/04/21 职场文书
python之PySide2安装使用及QT Designer UI设计案例教程
2021/07/26 Python
Win11 S Mode版本泄露 正式上线后叫做Windows 11 SE
2021/11/21 数码科技