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 相关文章推荐
[原创]站长必须要知道的javascript广告代码
May 30 Javascript
理解JavaScript的caller,callee,call,apply
Apr 28 Javascript
ie 调试javascript的工具
Apr 29 Javascript
Uglifyjs(JS代码优化工具)入门 安装使用
Apr 13 Javascript
JS弹出层的显示与隐藏示例代码
Dec 27 Javascript
深入理解javascript中的立即执行函数(function(){…})()
Jun 12 Javascript
jQuery弹出窗口简单实现代码
Mar 09 Javascript
给Easyui-Datebox设置隐藏或者不可用的解决方法
May 26 Javascript
angularjs数组判断是否含有某个元素的实例
Feb 27 Javascript
JS封装的模仿qq右下角消息弹窗功能示例
Aug 22 Javascript
基于JS判断对象是否是数组
Jan 10 Javascript
JavaScript缓动动画函数的封装方法
Nov 25 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
php 仿Comsenz安装效果代码打包提供下载
2010/05/09 PHP
关于UEditor编辑器远程图片上传失败的解决办法
2012/08/31 PHP
PHP耦合设计模式实例分析
2018/08/08 PHP
Laravel获取当前请求的控制器和方法以及中间件的例子
2019/10/11 PHP
javascript 模拟点击广告
2010/01/02 Javascript
jquery 插件学习(六)
2012/08/06 Javascript
js简单实现HTML标签Select联动带跳转
2013/10/23 Javascript
JavaScript转换二进制编码为ASCII码的方法
2015/04/16 Javascript
JS+CSS实现简单滑动门(滑动菜单)效果
2015/09/19 Javascript
JavaScript电子时钟倒计时第二款
2016/01/10 Javascript
jQuery中的一些常见方法小结(推荐)
2016/06/13 Javascript
如何使用headjs来管理和异步加载js
2016/11/29 Javascript
JS实现颜色动态淡化效果
2017/03/06 Javascript
jquery ajax加载数据前台渲染方式 不用for遍历的方法
2018/08/09 jQuery
使用vue点击li,获取当前点击li父辈元素的属性值方法
2018/09/12 Javascript
js实现搜索栏效果
2018/11/16 Javascript
说说如何使用Vuex进行状态管理(小结)
2019/04/14 Javascript
小程序云函数调用API接口的方法
2019/05/17 Javascript
js 使用ajax设置和获取自定义header信息的方法小结
2020/03/12 Javascript
[02:16]深扒TI7聊天轮盘语音出处2
2017/05/11 DOTA
布同 Python中文问题解决方法(总结了多位前人经验,初学者必看)
2011/03/13 Python
python目录操作之python遍历文件夹后将结果存储为xml
2014/01/27 Python
python简单实现刷新智联简历
2016/03/30 Python
基于pandas数据样本行列选取的方法
2018/04/20 Python
python创建文件备份的脚本
2018/09/11 Python
pytorch中图像的数据格式实例
2020/02/11 Python
python中列表的含义及用法
2020/05/26 Python
django 将自带的数据库sqlite3改成mysql实例
2020/07/09 Python
检测用户浏览器是否支持CSS3的方法
2009/08/29 HTML / CSS
HTML5 body设置自适应全屏
2020/05/07 HTML / CSS
瑜伽服装品牌:露露柠檬(lululemon athletica)
2017/06/04 全球购物
创建服务型党组织实施方案
2014/02/25 职场文书
需求分析说明书
2014/05/09 职场文书
导游词之无锡梅园
2019/11/28 职场文书
解决pycharm安装scrapy DLL load failed:找不到指定的程序的问题
2021/06/08 Python
Python实现PIL图像处理库绘制国际象棋棋盘
2021/07/16 Python