昨天在做项目的时候遇到个小问题,如何将自定义控件中的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代码依然为上面代码,这时该会报以下错误:

ASP.NET 自定义控件导出Excel

怎么解决呢?

我们只好这样做:

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

Page下增加如下代码:

public override void VerifyRenderingInServerForm(Control control)

{}

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

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

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

相关文章: