错误提示:类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记内

错误提示:类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记内

在做导出数据到EXCEL程序中,出现了错误提示:类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记

内,改了半天,就自己的经验一般情况下是因为<FORM>标签没有加runat="server"。但这在程序中是有的啊!最后查了很多资料,终于解决了。

在后台文件中重载VerifyRenderingInServerForm方法,如: /?"
public override void VerifyRenderingInServerForm(Control control)
{
     //base.VerifyRenderingInServerForm(control);
}

PS:VerifyRenderingInServerForm方法说明

Page.VerifyRenderingInServerForm 方法
确认在运行时为指定的 ASP.NET 服务器控件呈现 HTMLForm 控件。

[C#]public virtual void VerifyRenderingInServerForm(   Control control);参数
control
ASP.NET 服务器控件,它必须位于 HTMLForm 控件中。
异常
异常类型 条件
HttpException 指定的服务器控件在运行时不包含在 HTMLForm 服务器控件的开始和结束标记之间。

备注
如果该页当前不处于页处理中的呈现阶段,且位于 <form runat=server> 标记内,则该方法将引发异常。需要位于服务器窗体内

的控件可以在呈现期间调用该方法,以便在它们被放置到外面时显示明确的错误信息。发送回或依赖于注册的脚本块的控件应该在

Control.Render 方法的重写中调用该方法。呈现服务器窗体元素的方式不同的页可以重写该方法以在不同的条件下引发异常。

如果回送或使用客户端脚本的服务器控件没有包含在 HTMLForm 服务器控件 (<form runat="server">) 中,它们将无法正常工作

。这些控件可以在呈现时调用该方法,以在它们没有包含在 HTMLForm 控件中时提供明确的错误信息。

开发自定义服务器控件时,通常在为任何类型的输入标记重写 Render 方法时调用该方法。这在输入控件调用

GetPostBackEventReference 或发出客户端脚本时尤其重要。复合服务器控件不需要作出此调用。

除非要创建替换页框架,否则请不要重写此方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要改变GridView中行的颜色,您可以使用CSS样式或在后端代码中设置行的样式。 1. 使用CSS样式: 在CSS文件中定义一个类来设置行的样式,例如: ```css .highlight-row { background-color: red; // 设置背景颜色为红色 } ``` 然后,在GridView中的RowDataBound事件中,为符合条件的行添加该CSS类名。在代码-behind文件中: ```csharp protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e) { if (e.Row.RowType == DataControlRowType.DataRow) { int totalBalanceQty = Convert.ToInt32(DataBinder.Eval(e.Row.DataItem, "TotalBalanceQty")); int maximumInventory = Convert.ToInt32(DataBinder.Eval(e.Row.DataItem, "MaximumInventory")); if (totalBalanceQty > maximumInventory) { e.Row.CssClass = "highlight-row"; } } } ``` 2. 在后端代码中设置行的样式: 在GridView的RowDataBound事件中,为符合条件的行设置背景颜色,例如: ```csharp protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e) { if (e.Row.RowType == DataControlRowType.DataRow) { int totalBalanceQty = Convert.ToInt32(DataBinder.Eval(e.Row.DataItem, "TotalBalanceQty")); int maximumInventory = Convert.ToInt32(DataBinder.Eval(e.Row.DataItem, "MaximumInventory")); if (totalBalanceQty > maximumInventory) { e.Row.BackColor = Color.Red; } } } ``` 请注意,无论您选择使用CSS样式还是在代码-behind中设置样式,都需要在GridView中的RowDataBound事件中调用相应的方法。同时,确保您已将该事件与GridView绑定,例如: ```asp.net <asp:GridView ID="GridView1" AutoGenerateColumns="false" runat="server" OnRowDataBound="GridView1_RowDataBound"> ``` 这样,当某一行的可用库存大于最大库存时,该行就会显示为红色背景。记得根据您的需求进行适当的调整和修改。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值