GridView:根据单元格的值给单元格着色

     今天在做一个统计报表时,打算根据不同值给单元格选择不同的颜色。首先想到在前台用属性绑定,如

      <asp:BoundField HeaderText="测试" DataField="skdjf">
             <ItemStyle ForeColor='<%# Eval("字段").ToString()=="某值"?"Red":"Black" %>' />
      </asp:BoundField>
     但浏览后发现抛出“仅对具有 DataBinding 事件的对象提供数据绑定表达式支持。System.Web.UI.WebControls.TableItemStyle 没有 DataBinding 事件”的异常,原来ItemStyle的属性值是不能绑定值的。

      后来,使用rowdatabound事件轻易是解决了这个问题。例子如下:

      前台代码:

      <asp:GridView ID="GridView1" runat="server"
            onrowdatabound="GridView1_RowDataBound">
            <Columns>
            <asp:BoundField HeaderText="测试" DataField="skdjf">
            </asp:BoundField>
            </Columns>
     </asp:GridView>

     后台代码:

         protected void gvStudyPlanDetail_RowDataBound(Object sender, GridViewRowEventArgs e)
        {
            if (e.Row.RowType == DataControlRowType.DataRow)
            {
                e.Row.Cells[7].ForeColor=e.Row.Cells[8].ForeColor = e.Row.Cells[10].Text == "是" ? System.Drawing.Color.Red : System.Drawing.Color.Black;
            }
        }

posted @ 2010-12-02 23:17  涂墨留香  阅读(838)  评论(0编辑  收藏  举报