Control 'GridView1' of type 'GridView' must be placed inside a form tag with runat=server

 

Control 'GridView1' of type 'GridView' must be placed inside a form tag with runat=server

 

asp.net(C#) To Excel时出现这种错误!!

 

C# Code

 

    /// <summary>
    /// To Excel
    /// </summary>
    /// <param name="ctl">例如控件 GridView</param>

    private void ToExcel(Control ctl)
    {
        HttpContext.Current.Response.Charset = "UTF-8";
        HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8;
        HttpContext.Current.Response.ContentType = "application/ms-excel";
        HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=Excel.xls");
        ctl.Page.EnableViewState = false;
        System.IO.StringWriter tw = new System.IO.StringWriter();
        HtmlTextWriter hw = new HtmlTextWriter(tw);
        ctl.RenderControl(hw);
        HttpContext.Current.Response.Write(tw.ToString());
        HttpContext.Current.Response.End();

    }

 

然后才发现需要重写一个方法,加下面一段代码就可以搞定了.

 

    public override void VerifyRenderingInServerForm(Control control)
    {

 

    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要改变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"> ``` 这样,当某一行的可用库存大于最大库存时,该行就会显示为红色背景。记得根据您的需求进行适当的调整和修改。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值