有条件隐藏 GridView 模板列

问题描述

我正在尝试有条件地隐藏 Gridview 中的模板列,我尝试了以下操作,但这不起作用。有没有办法在 .aspx 中做到这一点?

 <asp:TemplateField HeaderText="Grade" SortExpression="grade" Visible='<%# Convert.Todouble(Eval("grade")) == 0 ? true : false %>'>
           <ItemTemplate>
                <%# string.Format("{0:0.#}",Convert.Todouble(Eval("grade"))) %>
           </ItemTemplate>
 </asp:TemplateField>

解决方法

您可以使用 itemDataBound 事件进行所有条件格式设置(颜色、隐藏等)。但是,您的示例标记似乎没有控制权 - 您想要控制该信息。并且该控件应该具有某种您可以在代码中引用的“id”或名称。

但是,由于您没有提供很多标记?然后,我将举例说明单元格集合和您可能拥有的控件。

所以,假设我们有这个简单的网格视图。请注意最后两个字段如何都是 City,一个是绑定字段(通常很常见),另一个是标签(但可以是文本框或几乎任何 asp.net 控件)。

      <asp:GridView ID="GridView1" runat="server" CssClass="table-hover" AutoGenerateColumns="False" DataKeyNames="ID">
            <Columns>
                <asp:BoundField DataField="ID" HeaderText="ID" InsertVisible="False" ReadOnly="True" SortExpression="ID" />
                <asp:BoundField DataField="FirstName" HeaderText="FirstName" SortExpression="FirstName" />
                <asp:BoundField DataField="LastName" HeaderText="LastName" SortExpression="LastName" />
                <asp:BoundField DataField="HotelName" HeaderText="HotelName" SortExpression="HotelName" />
                <asp:BoundField DataField="City" HeaderText="City" SortExpression="City" />

                <asp:TemplateField HeaderText ="City2">
                    <ItemTemplate>
                        <asp:Label ID="lblCity" runat="server" Text = '<%# Eval("City") %>'  >'<"></asp:Label>
                    </ItemTemplate>
                </asp:TemplateField>
            </Columns>
        </asp:GridView>

好的,在页面加载时,我们使用以下代码加载上面的网格:

protected void Page_Load(object sender,System.EventArgs e)
{
    if (IsPostBack == false)
        LoadGrid();
}

public void LoadGrid()
{
    using (SqlCommand cmdSQL = new SqlCommand("SELECT ID,FirstName,LastName,HotelName,City from tblHotels",new SqlConnection(My.Settings.TEST3)))
    {
        cmdSQL.Connection.Open();
        GridView1.DataSource = cmdSQL.ExecuteReader;
        GridView1.DataBind();
    }
}

好的,我们得到这个输出:

enter image description here

现在,让我们根据城市隐藏一列。我们说 City = "Edmonton",我们隐藏了控件。

因此,您使用 itemData 绑定事件。

我在此示例中既有绑定字段(单元格)集合隐藏示例,也有关于如何使用模板化控件(查找控件)执行此操作的示例。

所以,代码是这样的:

protected void GridView1_RowDataBound(object sender,GridViewRowEventArgs e)
{
   if (e.Row.RowType == DataControlRowType.DataRow)
   {
       GridViewRow gvRow = e.Row;

       // hide a Bound field
       TableCell f = gvRow.Cells(4);
       if (f.Text == "Edmonton")
           f.Style("Display") = "none";

       // hide a templated control

       Label lbl = gvRow.FindControl("lblCity");
       if (lbl.Text == "Edmonton")
           lbl.Style("Display") = "none";
   }
}

现在输出是这样的:

enter image description here