• 博客园logo
  • 会员
  • 周边
  • 新闻
  • 博问
  • 闪存
  • 众包
  • 赞助商
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
微软(北京).Net俱乐部-H2O、winnerzone
一个战士一旦穿上军装拿起武器就已经做好了战斗的准备,他将被派往无数战火纷飞的战场,每一次都会有生命的危险。
但是一旦他活下来了,那些都将成为光荣的历史被讲述和回忆。对于一个新兵,危险和机遇并存,机遇大于危险和压力。
博客园    首页    新随笔    联系   管理    订阅  订阅

ASP.NET 自定义控件导出Excel

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

昨天在做项目的时候遇到个小问题,如何将自定义控件中的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的帮助依然不懂.

WINNERZONE
posted @ 2007-08-06 11:07  H2O、winnerzone  阅读(1445)  评论(1)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2026
浙公网安备 33010602011771号 浙ICP备2021040463号-3