如何在TemplateField中设置前景

本文关键字:设置 TemplateField | 更新日期: 2023-09-27 18:30:07

评估性别后,下面的代码在GridView列中显示"M"或"F"。

        <asp:TemplateField HeaderText="Gender">
            <ItemTemplate>
                <%# Eval("Gender") %>
            </ItemTemplate>
        </asp:TemplateField>

当它是"M"时,我想使用文本颜色红色和蓝色,否则。我该怎么做?无论是在aspx文件中还是在代码隐藏中都可以。如果可能的话,我想知道这两种方法。

如何在TemplateField中设置前景

要通过标记来实现,您必须将项目模板内容包装到例如<div>中,并将必要的样式应用于它,如下所示:

<asp:TemplateField HeaderText="Gender">
    <ItemTemplate>
        <div style='color: <%# Eval("Gender") == "M" ? "Red" : "Blue" %>'>
            <%# Eval("Gender") %>
        </div>
    </ItemTemplate>
</asp:TemplateField>

您可以使用GridView上的onRowDataBound事件来检查"M"或"F",然后根据值更改字体颜色。

void gridview_RowDataBound(Object sender, GridViewRowEventArgs e)
{
if(e.Row.RowType == DataControlRowType.DataRow)
{
string theValue = e.Row.Cells[3].Text;
if (theValue ="M")
{
e.Row.Cells[1].Forecolor= Color.Red
}
else if (theValue ="F")
{
e.Row.Cells[1].Forecolor= Color.Blue;
}
}
}