我正在尝试将Gridview导出到excel。我将网格视图绑定到一个集合,可以看到它有6个数据行,但是当我调用RenderControl时,它返回一个空字符串。下面是我使用的代码
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方法。
发布于 2011-08-19 16:59:06
我最好的回答是,您已经将GridView的可见性设置为false。这将阻止控件呈现,因为……它现在是不可见的。结果是一个空字符串。
如果不想显示GridView,只需在执行渲染代码之前将可见性设置为true,然后再将其设置回去:
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方法:
public override void VerifyRenderingInServerForm(Control control)
{
return;
}https://stackoverflow.com/questions/7102587
复制相似问题