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;
}
}