簡體   English   中英

我是否可以基於gridview中未顯示的列中的值修改gridview中的列單元格文本?

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM