首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Gridvew.RenderControl返回空字符串

Gridvew.RenderControl返回空字符串
EN

Stack Overflow用户
提问于 2011-08-18 12:59:57
回答 1查看 2.7K关注 0票数 1

我正在尝试将Gridview导出到excel。我将网格视图绑定到一个集合,可以看到它有6个数据行,但是当我调用RenderControl时,它返回一个空字符串。下面是我使用的代码

代码语言:javascript
复制
Gridview1.DataSource = data;
Gridview1.DataBind();
System.IO.StringWriter sw = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter htw = new System.Web.UI.HtmlTextWriter(sw);
Gridview1.RenderControl(htw);
var outputHtml = sw.ToString();

当我检查outputHtml时,它是一个空字符串。我在这段代码中做错了什么。

需要注意的一件事是,gridview位于一个带有runat='server‘标记的表单中,并且我没有覆盖VerifyRenderingInServerForm方法。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-08-19 16:59:06

我最好的回答是,您已经将GridView的可见性设置为false。这将阻止控件呈现,因为……它现在是不可见的。结果是一个空字符串。

如果不想显示GridView,只需在执行渲染代码之前将可见性设置为true,然后再将其设置回去:

代码语言:javascript
复制
    gv_sample.Visible = true;
    System.IO.StringWriter sw = new System.IO.StringWriter();
    System.Web.UI.HtmlTextWriter htw = new System.Web.UI.HtmlTextWriter(sw);
    gv_sample.RenderControl(htw);
    var outputHtml = sw.ToString();
    gv_sample.Visible = false;

现在您可能会在使用RenderControl方法时遇到麻烦。如果是,请确保在Page指令中设置了EnableEventValidation="false"并覆盖VerifyRenderingInServerForm方法:

代码语言:javascript
复制
public override void VerifyRenderingInServerForm(Control control)
{
    return;
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7102587

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档