Rss & SiteMap
Foxtable(狐表) http://www.foxtable.com
在狐表weui教程里,直接通过Http请求,e.writeBook和e.WriteReportAsPDF都是可以顺利生成excel文件下载,或者是生成pdf下载
但是使用第三方框架时,也就是在Jquery的Ajax里、Vue的Axios里、Uniapp的Request方法里,都无法触发下载
但是在F12控制台里,能看到狐表已经做出回复,能收到服务器端发过来的数据
此主题相关图片如下:2.png
很多人以为是狐表的bug,这个生成方法只能用在weui。于是就用回传统的方法:
1先本地生成Excel/PDF
2然后把url链接发送给前端
3前端再触发下载
这种模式有2个问题:
1生成Excel或者专业报表的PDF时,是主线程同步的,多人用的时候,会出现性能问题。
2你稍微不注意,可能会并发同时生成同名同目录文件,导致文件重复写入占用,磁盘IO写入报错。严重的还会让程序一直在写入,把cpu飙升到100%占用(我最近遇到了)
狐表高开文档原文:“
1、虽然WriteFile是异步执行的,但是Excel报表的生成和保存却是和主线程同步的,且Excel报表的生成并非很高效,所以用户量比较大的时候,会影响效率。
2、整个过程要分别保存和读取一次文件,我们知道计算机性能的瓶颈就是硬盘的读写,所以这同样会影响效率。
3、由于要保存为实际的文件,所以容易出现文件名冲突,假定有多个用户同时访问,上面的代码肯定会出错,虽然可以采用一些手段避免同名冲突,但毕竟增加了工作量。”
所以最好的方案:还是用e.writeBook和e.WriteReportAsPDF,实现【异步生成+异步发送】
2问题分析
其实不是狐表有bug,而是你没理解e.writeBook和e.WriteReportAsPDF是通过什么机制,实现了“异步生成+异步发送”
实际上,这2个方法,都是把文件,直接生成为Blob二进制格式的文件流,直接发送给浏览器,浏览器已经成功接收了,见下图
那浏览器没能触发下载,是前端代码的问题,并不是狐表的问题。需要改动一些js代码。