这个假期都在做一个综合ASP.NET MVC、Webapi、jquery、ajax、easyui等技术和框架的高速公路大数据分析网站项目。系统用json做前后端通信的数据格式,后端主要用Webapi处理业务逻辑,并返回一个定制的消息对象,前端就是jquery、ajax和easyui等呈现和相关处理。
前面的文件上传、参数传递、CRUD操作、数据集合返回给easyui等都做得十分顺利。最后,要输出报表了。使用NPOI组件在后端生成一个Excel报表,然后像image处理一样转换成base64字符串格式,通过Webapi返回给前端浏览器。Chrome和Firefox均能很好地支持直接在浏览器里打开下载窗口,见如下代码:
function DownloadFile(xlsBase64)
{
if (!document.getElementById("dwnf"))
{
$(document.body).append('<a href="#" id="dwnf" style="display: none"></a>');
}
var reportName = $('#ReportNames').val();
var fileName = reportName + '_' + GetPeriodNo() + '.xls';
var url = '