GridView 导出到 Excel 文件报错解决办法(2)

 --转载自:http://hi.baidu.com/lhlsxdx/blog/item/7a57498b6db80c18c8fc7a9d.html

ASP.NET 2.0中将 GridView 导出到 Excel 文件中

下面代码实现将 GridView 导出到 Excel文件中。

值得注意的是VerifyRenderingInServerForm重载方法:

MSDN上的 VerifyRenderingInServerForm 方法的描述:

  必须位于 <form runat=server> 标记中的控件可以在呈现之前调用此方法,以便在控件被置于标记外时显示错误信息。发送回或依赖于注册的脚本块的控件应该在 Control.Render 方法的重写中调用此方法。呈现服务器窗体元素的方式不同的页可以重写此方法以在不同的条件下引发异常。

  如果回发或使用客户端脚本的服务器控件没有包含在 HtmlForm 服务器控件 (<form runat="server">) 标记中,它们将无法正常工作。这些控件可以在呈现时调用该方法,以在它们没有包含在 HtmlForm 控件中时提供明确的错误信息。

  开发自定义服务器控件时,通常在为任何类型的输入标记重写 Render 方法时调用该方法。这在输入控件调用 GetPostBackEventReference 或发出客户端脚本时尤其重要。复合服务器控件不需要作出此调用。

没有这个方法,程序将报错。

今天写了一个导出数据的代码,将数据导出到Excel和Doc中,方法如下:

protected void export_Click(object sender, EventArgs e)
        {
            Response.Clear();
            Response.Buffer = true;
            //Response.Charset = "GB2312";
            //设置输出文件类型为excel文件。
            Response.ContentType = "application/ms-excel";
            Response.AppendHeader("Content-Disposition", "attachment;FileName=boiler.xls");
            //经测试如果设置为 以下的编码方式一定要与Web.config页面的顶头上的<?xml version="1.0" encoding="UTF-8"?>中的一致
            Response.ContentEncoding = System.Text.Encoding.UTF8;
            System.IO.StringWriter oStringWriter = new System.IO.StringWriter();
            System.Web.UI.HtmlTextWriter oHtmlTextWriter = new System.Web.UI.HtmlTextWriter(oStringWriter);
            this.GridView1.RenderControl(oHtmlTextWriter);
            Response.Output.Write(oStringWriter.ToString());
            Response.Flush();
            Response.End();
        }

导出到Excel和Doc中:

运行时提示错误:System.Web.HttpException: 类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记内。此时增加:

   public override void VerifyRenderingInServerForm(Control control)
    {

    }

如果提示:System.InvalidOperationException: 只能在执行 Render() 的过程中调用 RegisterForEventValidation;哪是gridview的allowpaging属性设置为true则应该在<%@ Page Language="C#" Debug="true"   %>中增加EnableEventValidation="false" 属性。

如果用ajax控件还必须加this.ScriptManager1.RegisterPostBackControl(this.BtnDaoChu);或在客户端加 <asp:UpdatePanel ID="UpdatePanel1" runat="server" RenderMode="Block">
      <triggers>
                <asp:postbacktrigger controlid="BtnDaoChu" />
            </triggers>

            <ContentTemplate></ContentTemplate> </asp:UpdatePanel>

这样就一切OK啦!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值