Start Here..
当前编码的一个项目中有把查询结果(显示在DataGrid)导出为excel的需求,尝试了几种方法,作为技巧拿来和大家分享。 内容: 服务器端实现DataGrid导出为excel 客户端实现DataGrid导出为excel 服务器端实现DataTable导出为excel(终极解决方案)
服务器端实现DataGrid导出为excel 这是网上出现的最多的做法:
在需要导出的地方调用上面的方法就可以。不过这样的实现有两个问题:第一,datagrid中不能包含模板列;第二,只能够导出当前显示在datagrid的数据,无法在分页的情况下导出全部的查询结果。 如果大家分析一下Control.RenderControl的方法,就会发现RenderControl只是把控件的innerHTML导出来,既然如此,完全可以把导出操作放在客户端来处理。
客户端导出excel
下面是调用的例子
这种方法的缺点是: (1)了能够在客户端调用Excel.Application,需要把IE的安全级别设为“低”。 (2)与方法一相同,还是只能导出当前显示在datagrid里面的数据,无法导出分页的数据。
终极解决方案:将DataTable导出为excel 好,让我们快点结束这篇无聊的post。一般来说,页面上的datagrid是以查询得到的一个DataTable为数据源的。那么为了把全部数据导入excel中,我们只要把DataTable数据源输出为excel就可以了。
需要注意的是,导出excel之前要把datatable的列名更改为客户要求的文字,就ok了。因为是从DataTable导出的,所以这种方法解决了分页数据的问题,堪称终极解决方案。
posted on 2012-08-29 09:57 ** 阅读(400) 评论(0) 编辑 收藏
Powered by: BlogJava Copyright © **