Подтвердить что ты не робот

Как скрыть столбец TemplateField в GridView

Как скрыть столбец TemplateField в GridView?

Я попробовал следующее:

<asp:TemplateField ShowHeader="False" Visible='<%# MyBoolProperty %>' >
<ItemTemplate>
    <asp:LinkButton ID="attachmentButton" runat="server" ... />
</ItemTemplate>

но он не работает и дает следующую ошибку:

Выражения привязки поддерживаются только для объектов, имеющих событие DataBinding.     System.Web.UI.WebControls.TemplateField не имеет события DataBinding.

Я также попытался скрыть это программно, но, похоже, невозможно получить столбец по имени, потому что не существует имени столбца TemplateField.

4b9b3361

Ответ 1

protected void OnRowCreated(object sender, GridViewRowEventArgs e)
{
         e.Row.Cells[columnIndex].Visible = false;
}

<ч/" > Если вы не предпочитаете кодированный индекс, единственное обходное решение, которое я могу предложить, - это предоставить HeaderText для GridViewColumn, а затем найти столбец, используя HeaderText.

protected void UsersGrid_RowCreated(object sender, GridViewRowEventArgs e)
{
    ((DataControlField)UsersGrid.Columns
            .Cast<DataControlField>()
            .Where(fld => fld.HeaderText == "Email")
            .SingleOrDefault()).Visible = false;
}

Ответ 2

For Each dcfColumn As DataControlField In gvGridview.Columns
    If dcfColumn.HeaderText = "ColumnHeaderText" Then
        dcfColumn.Visible = false                    
    End If
Next

Ответ 3

Если мне кажется, что строки, в которых значение Visible равно false, не будут доступны, они будут удалены из DOM, а не скрыты, поэтому я также использовал подход Display: None. В моем случае я хотел иметь скрытый столбец, содержащий ключ строки. Для меня этот декларативный подход немного чище, чем некоторые другие подходы, которые используют код.

<style>
   .HiddenCol{display:none;}                
</style>


 <%--ROW ID--%>
      <asp:TemplateField HeaderText="Row ID">
       <HeaderStyle CssClass="HiddenCol" />
       <ItemTemplate>
       <asp:Label ID="lblROW_ID" runat="server" Text='<%# Bind("ROW_ID") %>'></asp:Label>
       </ItemTemplate>
       <ItemStyle HorizontalAlign="Right" CssClass="HiddenCol" />
       <EditItemTemplate>
       <asp:TextBox ID="txtROW_ID" runat="server" Text='<%# Bind("ROW_ID") %>'></asp:TextBox>
       </EditItemTemplate>
       <FooterStyle CssClass="HiddenCol" />
      </asp:TemplateField>

Ответ 4

GridView1.Columns[columnIndex].Visible = false;

Ответ 5

попробуйте это

.hiddencol
    {
        display:none;
    }
    .viscol
    {
        display:block;
    }

добавить следующий код в RowCreated Event из GridView

protected void OnRowCreated(object sender, GridViewRowEventArgs e)
{
     if (e.Row.RowType == DataControlRowType.DataRow)
     {
         e.Row.Cells[0].CssClass = "hiddencol";
     }
     else if (e.Row.RowType == DataControlRowType.Header)
     {
         e.Row.Cells[0].CssClass = "hiddencol";
     }
}

Ответ 6

protected void gvLogMessageDetail_RowDataBound(object sender, GridViewRowEventArgs e)  
    { 
      if (e.Row.RowType == DataControlRowType.Header)   
        {  
            if (rdlForImportOrExport.SelectedIndex == 1)  
            {  
                e.Row.Cells[3].Visible = false;  
                e.Row.Cells[4].Visible = false;  
                e.Row.Cells[5].Visible = false;  
            }  
            else  
            {  
                e.Row.Cells[3].Visible = true;  
                e.Row.Cells[4].Visible = true;  
                e.Row.Cells[5].Visible = true;  
            }  
        }    
        if (e.Row.RowType == DataControlRowType.DataRow) //skip header row  
        {  
            try  
            {  
                if (rdlForImportOrExport.SelectedIndex == 1)  
                {  
                    e.Row.Cells[3].Visible = false;  
                    e.Row.Cells[4].Visible = false;  
                    e.Row.Cells[5].Visible = false;  
                }  
                else  
                {  
                    e.Row.Cells[3].Visible = true;  
                    e.Row.Cells[4].Visible = true;  
                    e.Row.Cells[5].Visible = true;  
                }  
                }  
            catch  
            {  
                ClientScript.RegisterStartupScript(GetType(), "Expand", "<SCRIPT   LANGUAGE='javascript'>alert('There is binding problem in child grid.');</script>");  
            }  
        }  
    }  

Ответ 7

Я что-то пропустил?

Если вы не можете установить видимость на TemplateField, установите его на свой контент

<asp:TemplateField>
  <ItemTemplate>
    <asp:LinkButton Visible='<%# MyBoolProperty %>' ID="foo" runat="server" ... />
  </ItemTemplate>
</asp:TemplateField> 

или если ваш контент является сложным, заключите его в div и установите видимость на div

<asp:TemplateField>
  <ItemTemplate>
    <div runat="server" visible='<%# MyBoolProperty  %>' >
      <asp:LinkButton ID="attachmentButton" runat="server" ... />
    </div>
  </ItemTemplate>
</asp:TemplateField> 

Ответ 8

Это может быть другой способ сделать это и проверить нули

DataControlField dataControlField = UsersGrid.Columns.Cast<DataControlField>().SingleOrDefault(x => x.HeaderText == "Email");
            if (dataControlField != null)
                dataControlField.Visible = false;

Ответ 9

Небольшое улучшение с использованием имени столбца, IMHO:

    Private Sub GridView1_Init(sender As Object, e As System.EventArgs) Handles GridView1.Init
    For Each dcf As DataControlField In GridView1.Columns
        Select Case dcf.HeaderText.ToUpper
            Case "CBSELECT"
                dcf.Visible = Me.CheckBoxVisible
                dcf.HeaderText = "<small>Select</small>"
        End Select
    Next
End Sub

Это позволяет контролировать несколько столбцов. Сначала я использую имя "технического" столбца, соответствующее внутреннему имени элемента управления. Это делает очевидным на странице ASCX, что это столбец управления. Затем замените имя по желанию для презентации. Если я шпионю странное имя в производстве, я знаю, что я что-то пропустил. "ToUpper" позволяет избежать проблем с ситуациями.

Наконец, это запускает ОДИН время в любой записи вместо захвата события во время создания строки.