时间:2021-05-26
乍一听有点蒙,之前用ng和react时也写过类似的功能,但是很顺利(所以忘记具体细节了)。jquery为啥会不行呢?看了一下具体场景,发现原来jq的ajax回调已经把response的数据傻瓜式的以字符串的方式解析了。
查了一下gg,发现国内的解决方案就是在该场景下不实用jq,而是自己手动创建XMLHttpRequest。虽然这个方法很可靠,但之前封装的jq的ajax就不能使用了。
查了查jq的文档,本打算自己根据jq提供的jQuery.ajaxSetup()接口来拓展数据类型,但怎么都搞不定。后来,在github上找到了一个大牛封装好的jq插件。
然后我们就可以这么写了:
<!DOCTYPE html><html><head><meta charset="utf-8"><title>blob demo</title></head><body><img id="img" src="" /><script src="//cdn.bootcss.com/jquery/2.2.1/jquery.js" charset="utf-8"></script><script src="jquery-ajax-blob-arraybuffer.js"></script><script type="text/javascript">$.ajax({url: "./face.jpg",type: "get",dataType: "blob", //扩展出了blob类型}).done(function(data, status, jqXHR){var reader = new window.FileReader();reader.readAsDataURL(data);reader.onloadend = function() {document.getElementById("img").src=reader.result;}}).fail(function(jqXHR, textStatus) {console.warn(textStatus);});</script></body></html>不过,从该插件的源码上来看,它也是手动构建了一个XMLHttpRequest对象来发送ajax,不过兼容性可能会成为问题。想深究的可以看这里。
以上所述是小编给大家介绍的jQuery的ajax下载blob文件 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
摘要:ajax请求一个二进制流(文件),转换为Blob进行处理或者下载保存文件需求管理后台需要随时下载数据报表,数据要实时生成后转换为excel下载。文件不大,
需求:通过后端接口下载excel文件,后端没有文件地址,返回二进制流文件实现:axios(ajax类似)主要代码:axios:设置返回数据格式为blob或者ar
本文实例讲述了javascript使用Blob对象实现的下载文件操作。分享给大家供大家参考,具体如下:Blob对象前言环境操作总结Blob是一个类文件的不可变的
复制代码代码如下://Ajax文件下载jQuery.download=function(url,data,method){//获取url和dataif(url&
本文实例讲述了php+ajax实现文件切割上传功能。分享给大家供大家参考,具体如下:html5中的File对象继承Blob二进制对象,Blob提供了一个slic