javascript使用Blob对象实现的下载文件操作示例


Posted in Javascript onApril 18, 2020

本文实例讲述了javascript使用Blob对象实现的下载文件操作。分享给大家供大家参考,具体如下:

Blob对象

  • 前言
  • 环境
  • 操作
  • 总结

Blob是一个类文件的不可变的原始数据对象,非javascript原生数据类型,File对象就是继承自Blob对象,且在Blob的基础上进行扩展,以便支持用户系统上的文件。

前言

最近在做以post请求方式导出excel时,想到了可以使用Blob对象将后台返回的输出流以arraybuffer或blob的格式接收交给Blob处理,最后使用URL生成链接,供浏览器下载excel。

环境

  1. vue2.x
  2. webpack3.x
  3. axios

操作

import axios from 'axios'
/**
* 从服务器下载excel
*/
function downloadExcel (settings) {
 const defaultOptions = {
  responseType: 'arraybuffer'
 }
 Object.assign(settings.options, defaultOptions)
 requestToResponse(settings).then(res => {
  const filename = decodeURI(res.headers['content-disposition'].split('filename=')[1])
  if ('download' in document.createElement('a')) {
   downloadFile(res.data, filename)
  } else {
   Message.error('浏览器不支持')
  }
 })
}
/**
* 发送http请求
* @param {Object} settings api参数
* @returns reponse
*/
function requestToResponse (settings) {
  const defaultParams = {
  timeout: 45000,
  headers: {
   'X-Requested-With': 'XMLHttpRequest',
   'Content-Type': 'application/json'
  },
  responseType: 'json',
  method: 'POST'
 }
 Object.assign(defaultParams, settings)
  return new Promise((resolve, reject) => {
  axios(defaultParams).then(res => {
   resolve(res)
  }).catch(err => {
   reject(err)
  })
 })
}
/**
* blob下载(兼容IE)
* @param {String} content 文件内容
* @param {String} filename 文件名
*/
function downloadFile (content, filename) {
 const blob = new Blob([content])
 // IE
 if (window.navigator && window.navigator.msSaveOrOpenBlob) {
  window.navigator.msSaveOrOpenBlob(blob, filename)
 } else {
  imatateDownloadByA(window.URL.createObjectURL(blob), filename)
 }
}
/**
* 通过a标签模拟下载
* @param {String} href
* @param {String} filename
*/
function imatateDownloadByA (href, filename) {
 const a = document.createElement('a')
 a.download = filename
 a.style.display = 'none'
 a.href = href
 document.body.appendChild(a)
 a.click()
 a.remove()
 window.URL.revokeObjectURL(href)
}

// 下载excel
downloadExcel({
  url: '/default/excel/export',
  responseType: 'arraybuffer'
})

responseType设置为arraybuffer
javascript使用Blob对象实现的下载文件操作示例
responseTyp设置成blob
javascript使用Blob对象实现的下载文件操作示例
不设置responseType,出现乱码
javascript使用Blob对象实现的下载文件操作示例
若引入mockjs,其拦截响应,重置了responseType,会出现乱码
javascript使用Blob对象实现的下载文件操作示例

总结

  1. 此下载excel只适用于post请求,get请求交给浏览器自行解析处理
  2. responseType必须设置成arraybuffer或blob
  3. 下载excel时务必关闭mockjs之类的拦截响应的服务

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
jQuery 获取和设置select下拉框的值实现代码
Nov 08 Javascript
高性能JavaScript循环语句和条件语句
Jan 20 Javascript
jQuery实现弹出带遮罩层的居中浮动窗口效果
Sep 12 Javascript
JavaScript 中 apply 、call 的详解
Mar 21 Javascript
简单实现jQuery手风琴效果
Aug 18 jQuery
详解vue中引入stylus及报错解决方法
Sep 22 Javascript
Three.js基础学习之场景对象
Sep 27 Javascript
AngularJS使用ng-repeat遍历二维数组元素的方法详解
Nov 11 Javascript
讲解vue-router之什么是编程式路由
May 28 Javascript
Ajax请求时无法重定向的问题解决代码详解
Jun 21 Javascript
vue项目打包后提交到git上为什么没有dist这个文件的解决方法
Sep 16 Javascript
vue实现移动端返回顶部
Oct 12 Javascript
原生js实现的观察者和订阅者模式简单示例
Apr 18 #Javascript
es6函数name属性功能与用法实例分析
Apr 18 #Javascript
es6数组includes()用法实例分析
Apr 18 #Javascript
es6数组的flat(),flatMap()函数用法实例分析
Apr 18 #Javascript
es6函数中的作用域实例分析
Apr 18 #Javascript
es6函数之rest参数用法实例分析
Apr 18 #Javascript
vue实现短信验证码输入框
Apr 17 #Javascript
You might like
phpinfo 系统查看参数函数代码
2009/06/05 PHP
探讨PHP JSON中文乱码的解决方法详解
2013/06/06 PHP
php快速查找数据库中恶意代码的方法
2015/04/01 PHP
PHP实现根据银行卡号判断银行
2015/04/29 PHP
js CSS操作方法集合
2008/10/31 Javascript
javascript AutoScroller 函数类
2009/05/29 Javascript
JavaScript 学习笔记之基础中的基础
2015/01/13 Javascript
简单谈谈javascript代码复用模式
2015/01/28 Javascript
JavaScript事件委托技术实例分析
2015/02/06 Javascript
Javascript 实现微信分享(QQ、朋友圈、分享给朋友)
2016/10/21 Javascript
Bootstrap基本样式学习笔记之表单(3)
2016/12/07 Javascript
AngularJS表单验证功能
2017/10/19 Javascript
jQuery插件实现弹性运动完整示例
2018/07/07 jQuery
微信小程序获取复选框全选反选选中的值(实例代码)
2019/12/17 Javascript
在vue项目中promise解决回调地狱和并发请求的问题
2020/11/09 Javascript
pymongo实现控制mongodb中数字字段做加法的方法
2015/03/26 Python
Python中函数参数设置及使用的学习笔记
2016/05/03 Python
Centos Python2 升级到Python3的简单实现
2016/06/21 Python
浅谈python类属性的访问、设置和删除方法
2016/07/25 Python
python导入csv文件出现SyntaxError问题分析
2017/12/15 Python
matplotlib设置legend图例代码示例
2017/12/19 Python
详解PyTorch批训练及优化器比较
2018/04/28 Python
如何安装并使用conda指令管理python环境
2019/07/10 Python
利用python实现短信和电话提醒功能的例子
2019/08/08 Python
python3实现往mysql中插入datetime类型的数据
2020/03/02 Python
解决jupyter notebook 前面书写后面内容消失的问题
2020/04/13 Python
python初步实现word2vec操作
2020/06/09 Python
pytorch 移动端部署之helloworld的使用
2020/10/30 Python
前端canvas水印快速制作(附完整代码)
2019/09/19 HTML / CSS
Marlies Dekkers内衣美国官方网上商店:高端内衣品牌
2018/11/12 全球购物
Nanushka官网:匈牙利服装品牌
2019/08/14 全球购物
写给女朋友的道歉信
2014/01/08 职场文书
优秀党务工作者事迹材料
2014/05/07 职场文书
演讲稿的写法
2014/05/19 职场文书
2015年社区卫生工作总结
2015/04/21 职场文书
我的生日感言
2015/08/03 职场文书