异步导出excel
最近看园里有几篇写有关导出导入excel的博客,我正好最近在项目中也有涉及想来一起分享一下,正好整理一下自己的思路。
一、异步的方式是通过iframe来实现,代码如下:
if ($('#downloadexcel').length <= 0)
$('body').append("<iframe id=\"downloadexcel\" style=\"display:none\"></iframe>");
$('#downloadexcel').attr('src', url);
二、生成excel文件用的第三方组件NPOI,具体如何用园子里有很多关于这方面的资料,这里就不展开了。
三、这里主要介绍一下如何简化HttpResponse到前端生成excel,下面会贴出核心代码,希望给大家有所帮助。
- 声明一个excel返回实体,代码如下:
/// <summary>
/// 表示返回的流数据。
/// </summary>
[DataContract]
public class ExcelResultMessage
{
#region [ Privates ] private MessageType type = MessageType.Info;
private string description = string.Empty; #endregion #region [ Properteis ] /// <summary>
/// 返回结果信息提示类型。
/// </summary>
[DataMember(Order=)]
public MessageType Type
{
get { return this.type; }
set { this.type = value; }
} /// <summary>
/// 返回结果信息提示。
/// </summary>
[DataMember(Order=)]
public string Description
{
get { return this.description; }
set { this.description = value; }
} /// <summary>
/// 返回结果数据。
/// </summary>
[DataMember(Order=)]
public MemoryStream Data { get; set; } /// <summary>
/// 文件名
/// </summary>
[DataMember(Order = )]
public string FileName { get; set; } #endregion
} - 声明一个excel数据容器,代码如下:
/// <summary>
/// 表示返回的excel数据容器。
/// </summary>
[DataContract]
public class ExcelResult
{
#region [ Properteis ] /// <summary>
/// 编码格式。
/// </summary>
public Encoding ContentEncoding { get; set; } /// <summary>
/// 内容类型。
/// </summary>
public string ContentType { get; set; } /// <summary>
/// 数据。
/// </summary>
[DataMember]
public ExcelResultMessage Message { get; set; } #endregion #region [ Methods ] /// <summary>
/// 执行结果。
/// </summary>
/// <param name="context"></param>
public void ExecuteResult(HttpContext context)
{
if (context == null)
{
throw new ArgumentNullException("context");
} HttpResponse response = context.Response;
response.ClearContent();
if (!String.IsNullOrEmpty(ContentType))
{
response.ContentType = ContentType;
}
else
{
response.ContentType = "application/vnd.ms-excel";
}
if (ContentEncoding != null)
{
response.ContentEncoding = ContentEncoding;
} response.Clear();
if (this.Message != null)
{
response.AddHeader("Content-Disposition", string.Format("attachment;filename={0}", this.Message.FileName));
response.BinaryWrite(this.Message.Data == null ? new byte[] : this.Message.Data.GetBuffer());
response.End();
}
} #endregion
} - 声明一个excel页面基类,代码如下:
/// <summary>
/// excel页面基类。
/// </summary>
public abstract class ExcelPageBase : PageBase
{
#region [ Privates ] #endregion #region [ Contructors ] /// <summary>
///
/// </summary>
public ExcelPageBase()
: base()
{
} #endregion #region [ Properties ] /// <summary>
/// excel数据结果。
/// </summary>
protected ExcelResult ExcelResult { get; set; } #endregion #region [ Events ] /// <summary>
/// 页面加载。
/// </summary>
protected override void OnPreRender(EventArgs e)
{
SetNoCache();
this.ExcelResult = new ExcelResult();
GenerateExcelResult(this.ExcelResult);
ExcelResult.ExecuteResult(this.Context);
} /// <summary>
/// 集成Json结果数据。
/// </summary>
protected abstract void GenerateExcelResult(ExcelResult result); #endregion
} - 在实际导出excel中,只要实现这个excel页面基类,然后关注如何生成excel的MemoryStream就可以了,实例代码如下:
public partial class ExportFile : ExcelPage
{
protected override void GenerateExcelResult(ExcelResult result)
{
result.Message = new ExcelResultMessage();
SaleOrderResponse response = FinanceService.GetSaleOrderResponse(SaleModel.BuildSaleOrderQueryCondition(this.UserInfo), true);
MemoryStream stream = SaleModel.ExportToExcel(response);
result.Message.Data = stream;
result.Message.FileName = HttpUtility.UrlEncode(string.Format("{0}{1}.xls", this.BuildContent("AuditSaleOrder"), DateTime.Now.ToString("yyyyMMddhhmmss")));
}
}
异步导出excel的更多相关文章
- 多线程异步导出excel
先新建一个执行类 @Service public class MultiService { private static final Logger logger = LoggerFactory.get ...
- POI导出Excel不弹出保存提示_通过ajax异步请求(post)到后台通过POI导出Excel
实现导出excel的思路是:前端通过ajax的post请求,到后台处理数据,然后把流文件响应到客户端,供客户端下载 文件下载方法如下: public static boolean downloadLo ...
- ASP.NET MVC导出excel(数据量大,非常耗时的,异步导出)
要在ASP.NET MVC站点上做excel导出功能,但是要导出的excel文件比较大,有几十M,所以导出比较费时,为了不影响对界面的其它操作,我就采用异步的方式,后台开辟一个线程将excel导出到指 ...
- MVC学习笔记---MVC导出excel(数据量大,非常耗时的,异步导出)
要在ASP.NET MVC站点上做excel导出功能,但是要导出的excel文件比较大,有几十M,所以导出比较费时,为了不影响对界面的其它操作,我就采用异步的方式,后台开辟一个线程将excel导出到指 ...
- Java 导出Excel的各种尝试
最近的一个项目比较忙,一直没时间过来跟新博客.今天过来分享一下在此项目中遇到的一个小问题:导出Excel:相信导出Excel这个功能是特别常见的,也有很多的方式.好了,不多说了,直接说说自己遇到的各种 ...
- 使用NPOI导出Excel引发异常(IsReadOnly = “book.IsReadOnly”引发了类型“System.NotImplementedException”的异常)
前言: 本人调式npoi导入.导出试用成功后,引入到项目中,导入完美运行,但是导出怎么样都看不到现在的页面,而且浏览器和后台都没有报任务错误,让人好事纳闷,后来去调式,发现在除了一个IsReadOnl ...
- java POI导出Excel文件数据库的数据
在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作.这里我简单实现导出Excel文件. POI jar ...
- 采用Post请求的方式提交参数并导出excel
一般情况下,我们都是采用get请求的方式导出excel.例如采用如下方式: var exportUrl = '/xxx;'; window.open(exportUrl); 导出excel所需的逻辑参 ...
- PHP配合JS导出Excel大量数据
一般使用PHP导出Excel表格都会用PHPExcel,但是当遇到要导出大量数据时,就会导致超时,内存溢出等问题.因此在项目中放弃使用这种方式,决定采用前段生成Excel的方式来解决问题. 步骤如下: ...
随机推荐
- (转)C#调用非托管Win 32 DLL
转载学习收藏,原文地址http://www.cnblogs.com/mywebname/articles/2291876.html 背景 在项目过程中,有时候你需要调用非C#编写的DLL文件,尤其在使 ...
- Android开发-API指南-Fragment
Fragments 英文原文:http://developer.android.com/guide/components/fragments.html 采集日期:2014-12-31 在本文中 设计理 ...
- flex的Cairngorm框架
由于要写flex的项目,接触了一段时间的Cairngorm框架,初步认识它是flex的一个mvc结构的框架实现了页面,调用相应方法的控制,和后台交互之间的三层之间的联系.Cairngorm框架主要包括 ...
- qt+2012+qtcreator 配置
这个配置搞了我好久,终于搞定了,网上一大堆,总是看不懂,后来自己摸索出来的. 先贴图: 如上图:有两种配置方案: 第一:用vs2012做开发编辑.只要下载和对应插件即可,安装路径不要有空格.安装好之后 ...
- idea 下的maven使用问题汇总
1,-Dmaven.multiModuleProjectDirectory system propery is not set. Check $M2_HOME environment variable ...
- [drp 5] pageModel的建立,实现分页查询
导读:之前做的分页,一直都是用的easy--UI分页,然后没有系统的整理过,就是知道传几个参数,然后云云.这次,从头到尾总结一下,了了我的这桩心愿.人事系统的重定向工作,一直刺激着我一定要总结总结这个 ...
- Js获取当前日期时间及其它操作(转)
var myDate = new Date();myDate.getYear(); //获取当前年份(2位)myDate.getFullYear(); //获取完整的年份(4位,1 ...
- [zt]Which are the 10 algorithms every computer science student must implement at least once in life?
More important than algorithms(just problems #$!%), the techniques/concepts residing at the base of ...
- markdown语法学习源码
__注: 结合markdown官方文档 其中大部分例子和说明文字都摘自官方文档__官方链接:[Markdown: Basics (快速入门)](http://wowubuntu.com/markdow ...
- solr5.5教程-solrconfig.xml,加载schema.xml
布署完成后,接下来要更深入的研究solr的原理和使用. 首先进入testcore这个文件夹下面,发现这个core的conf里并没有schema.xml.那么数据格式是在哪里定义的呢? 打开 solr_ ...