摘要: ajax请求一个二进制流(文件),转换为Blob进行处理或者下载保存文件

需求
管理后台需要随时下载数据报表,数据要实时生成后转换为excel下载。
文件不大,页面放置“导出”按钮,点击按钮后弹出保存文件对话框保存
说明:第一种方法使用a标签直接可以满足大部分人需求,第二种方法纯粹是在说实现方法以及更好的操作体验,不需要(举一个需要第二种方法的例子:如果生成很慢就需要生成过程中禁用按钮,防止连续生成)用到的可以不用看
解决方案
方法一
请求文件的接口能改为GET则可以使用这种方法
<a class="btn btn-primary btn-xs" download="data.xlsx" href="download/?filename=aaa.txt" rel="external nofollow" ><i class="fa fa-share-square-o fa-lg"></i> 导出</a>
或者变换一种方式,使用js动态创建a标签
<button type="button" onclick="download()">导出</button>
function download() {
var a = document.createElement('a');
var url = 'download/?filename=aaa.txt';
var filename = 'data.xlsx';
a.href=url;
a.download = filename;
a.click()
}
缺点
不能使用post方法
不能在启动下载时禁用按钮、下载完毕启用按钮
方法二
很多人都在说第一种方法可以满足, 错误方式
常规方法,使用jquery:
<button type="button" onclick="download()">导出</button>
function download() {
var url = 'download/?filename=aaa.txt';
$.get(url, function (data) {
console.log(typeof(data))
blob = new Blob([data])
var a = document.createElement('a');
a.download = 'data.xlsx';
a.href=window.URL.createObjectURL(blob)
a.click()
})
}
这种方式保存的文件是不能打开的,console.log(typeof(data))会看到是string类型,原因是jquery将返回的数据转换为了string,不支持blob类型。
正确方式
<button type="button" onclick="download()">导出</button>
function download() {
var url = 'download/?filename=aaa.txt';
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true); // 也可以使用POST方式,根据接口
xhr.responseType = "blob"; // 返回类型blob
// 定义请求完成的处理函数,请求前也可以增加加载框/禁用下载按钮逻辑
xhr.onload = function () {
// 请求完成
if (this.status === 200) {
// 返回200
var blob = this.response;
var reader = new FileReader();
reader.readAsDataURL(blob); // 转换为base64,可以直接放入a表情href
reader.onload = function (e) {
// 转换完成,创建一个a标签用于下载
var a = document.createElement('a');
a.download = 'data.xlsx';
a.href = e.target.result;
$("body").append(a); // 修复firefox中无法触发click
a.click();
$(a).remove();
}
}
};
// 发送ajax请求
xhr.send()
}
总结
以上所述是小编给大家介绍的Ajax请求二进制流进行处理(ajax异步下载文件)的简单方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# ajax
# 请求二进制流
# ajax异步下载文件
# ajax post下载flask文件流以及中文文件名问题
# javascript写一个ajax自动拦截并下载数据代码实例
# SpringMVC+Ajax实现文件批量上传和下载功能实例代码
# 利用 FormData 对象和 Spring MVC 配合实现Ajax文件下载功能
# 基于Blod的ajax进度条下载实现示例代码
# PHP中ajax无刷新上传图片与图片下载功能
# 使用Ajax生成的Excel文件并下载的实例
# jQuery的ajax下载blob文件
# jQuery+Ajax+PHP弹出层异步登录效果(附源码下载)
# PHP+Ajax实现无刷新分页实例详解(附demo源码下载)
# 前端ajax请求+后端java实现的下载zip压缩包功能示例
# 种方法
# 转换为
# 小编
# 流进
# 保存文件
# 是在
# 都在
# 在此
# 不需要
# 很多人
# 能在
# 给大家
# 弹出
# 可以直接
# 不支持
# 可以使用
# 则可
# 所述
# 对话框
# 很慢
相关文章:
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
如何在IIS服务器上快速部署高效网站?
TestNG的testng.xml配置文件怎么写
如何在万网ECS上快速搭建专属网站?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
图册素材网站设计制作软件,图册的导出方式有几种?
重庆市网站制作公司,重庆招聘网站哪个好?
测试制作网站有哪些,测试性取向的权威测试或者网站?
子杰智能建站系统|零代码开发与AI生成SEO优化指南
Swift中循环语句中的转移语句 break 和 continue
javascript中的try catch异常捕获机制用法分析
如何选择高效可靠的多用户建站源码资源?
如何快速搭建支持数据库操作的智能建站平台?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?
建站之星多图banner生成与模板自定义指南
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
小说建站VPS选用指南:性能对比、配置优化与建站方案解析
如何通过商城自助建站源码实现零基础高效建站?
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
如何在阿里云完成域名注册与建站?
建站主机服务器选型指南与性能优化方案解析
建站之星免费版是否永久可用?
在线制作视频网站免费,都有哪些好的动漫网站?
深圳网站制作案例,网页的相关名词有哪些?
企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?
昆明高端网站制作公司,昆明公租房申请网上登录入口?
制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
建站之星安装模板失败:服务器环境不兼容?
5种Android数据存储方式汇总
c# 在ASP.NET Core中管理和取消后台任务
建站之星安装路径如何正确选择及配置?
宝塔建站无法访问?如何排查配置与端口问题?
如何安全更换建站之星模板并保留数据?
宝塔新建站点为何无法访问?如何排查?
如何选择高效响应式自助建站源码系统?
武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?
如何选择高效稳定的ISP建站解决方案?
如何在云主机快速搭建网站站点?
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
如何通过虚拟主机空间快速建站?
如何快速建站并高效导出源代码?
内网网站制作软件,内网的网站如何发布到外网?
如何制作算命网站,怎么注册算命网站?
如何在Ubuntu系统下快速搭建WordPress个人网站?
如何用PHP快速搭建高效网站?分步指南
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
*请认真填写需求信息,我们会在24小时内与您取得联系。