[英]Can I modify column cell text from a gridview based on a value from a column that isn't displayed in the gridview?
我有一個asp gridview,我想根據數據庫中標題為“ Completed”的列中的值更改單元格上文本的顏色,但我不希望該列包含在gridview中。
我希望在網格視圖中顯示三列:User | Form#| Department
如果該表單在數據庫中標記為未完成,則Form#文本的列單元格將為紅色。
現在,我通過添加不想在gridview中顯示的列來使它正常工作,如下所示:User | Form#| Department | Completed
在SQLdatasource中,我有查詢:
Select User, Form, Dept,
CASE Finished
WHEN 'True' THEN (' ')
WHEN 'False' THE ('!')
END AS Finished FROM Test1
在代碼背后:
if (Completed == "True")
{
cell3.ForeColor = Color.Red;
}
這可行,但是我不希望在gridview中顯示標題為Completed的列。 這可能嗎?
使用GridView TemplateFields而不是將自動生成的列設置為true。
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="false" OnRowDataBound="GridView1_RowDataBound">
<Columns>
<asp:TemplateField HeaderText="User">
<ItemTemplate>
<%# Eval("User") %>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Form">
<ItemTemplate>
<%# Eval("Form") %>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Dept">
<ItemTemplate>
<%# Eval("Dept") %>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
更新
若要檢查綁定到GridView的數據的值,請使用OnRowDataBound
事件。
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
//check if the row is a datarow
if (e.Row.RowType == DataControlRowType.DataRow)
{
//cast the dataitem back to a row
DataRowView row = e.Row.DataItem as DataRowView;
//check the value and set the backcolor
if (Convert.ToBoolean(row["Finished"]) == true)
{
e.Row.BackColor = Color.Red;
}
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.