• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ASP.NET 自定义控件导出Excel

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

昨天在做项目的时候遇到个小问题,如何将自定义控件中的Gridview的数据导出成Excel.

代码如下:

   Response.Clear();

        Response.Buffer = true;

        Response.Charset = "GB2312";

        Response.AppendHeader("Content-Disposition", "attachment;filename=FileName.xls");

        // 如果设置为 GetEncoding("GB2312");导出的文件将会出现乱码!!!

        Response.ContentEncoding = System.Text.Encoding.UTF7;

        Response.ContentType = "application/ms-excel";//设置输出文件类型为excel文件。

        System.IO.StringWriter ws= new System.IO.StringWriter();

        HtmlTextWriter htw = new HtmlTextWriter(sw);

        gvUsers.RenderControl(oHtmlTextWriter);

        Response.Output.Write(sw.ToString());

        Response.Flush();

        Response.End();

但是有个问题.该代码只能建立在当前页面是一个Page的情况下使用.

也就是说如果你把要导出的Gridview放在一个页面下使用上面的代码是可以成功的.


但是我的页面里有一个自定义的WebControl,要导出的Gridview是放在该自定义的WebControl中的,导出成Excel代码依然为上面代码,这时该会报以下错误:


怎么解决呢?

我们只好这样做:

在放这个自定义控件的Page下重写Page的VerifyRenderingInServerForm方法.

Page下增加如下代码:

public override void VerifyRenderingInServerForm(Control control)

{}

那么这个方法是干什么的呢?

该方法是确认在运行时为指定的 ASP.NET 服务器控件呈现 HtmlForm 控件。

那为什么要重写该方法而不去做任何事情呢?哪位大虾解释下.看了msdn的帮助依然不懂.

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap