ASP.NET 自定义控件导出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的帮助依然不懂.
posted @ 2007-08-06 11:07 H2O、winnerzone 阅读(451) 评论(1)  编辑 收藏

  回复  引用  查看    
#1楼 2007-08-06 15:23 | Clark Zheng      
自定义控件是服务器控件,其基类在自绘时会调用VerifyRenderingInServerForm验证是否在一个“<form runat=server></form>”中间,你的输出里没有这个form所以会出错,而重载该虚函数却什么事都不做相当于你的自定义控件在验证时什么都不做,所以不出错了

标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
 
另存  打印