0

私は VB .NET を使用しており、4 つの列(削除、ダウンロード、ノーム、および PK)を持つ GridView があります。列「名前」と「ID」は、SQL コマンドの結果であり、列「PK」をユーザーに非表示にしたいと考えています。しかし、私はそれをすることができませんでした。いくつかのコードを試しましたが、何もしませんでした。

これが私のコードです:

  Public Sub obterTabela()
        Dim db As DbConnect = New DbConnect()
        Dim conn = New SqlConnection(db.geraConnString)
        Dim cmd As New SqlCommand()
        Dim aux As String = System.IO.Path.GetFileName(System.Web.HttpContext.Current.Request.Url.Query)
        aux = aux.Replace("?id=", "")
        Dim conjunto As Integer = Convert.ToInt32(aux)

        conn.Open()
        'alterar
        cmd = New SqlCommand("SELECT nome AS 'Nome', pk_table AS 'PK' FROM t_kml WHERE fk_table = " & aux, conn)

        Dim dt As DataTable = New DataTable()
        Dim sdr As SqlDataReader = cmd.ExecuteReader(CommandBehavior.CloseConnection)
        dt.Load(sdr)
        'Dim indice As Integer = (Integer).Parse(dt.Columns("PK"))

        'dt.Columns.Item("PK").ColumnMapping = MappingType.Hidden

        sdr.Close()

        gdv_kml.DataSource = dt
        'gdv_kml.Columns(2).Visible = False
        gdv_kml.DataBind()
    End Sub

<asp:GridView ID="gdv_kml" runat="server" HorizontalAlign="Center" CellPadding="4" 
            ForeColor="#333333" GridLines="None">
            <RowStyle BackColor="#E3EAEB" />
            <Columns>
                <asp:CommandField ShowDeleteButton="True" />
                <asp:ButtonField CommandName="Download" Text="Download" />
            </Columns>
            <FooterStyle BackColor="#1C5E55" Font-Bold="True" ForeColor="White" />
            <PagerStyle BackColor="#666666" ForeColor="White" HorizontalAlign="Center" />
            <EmptyDataTemplate>
                <b>Nenhum KML incluso.</b>
            </EmptyDataTemplate>
            <SelectedRowStyle BackColor="#C5BBAF" Font-Bold="True" ForeColor="#333333" />
            <HeaderStyle BackColor="#1C5E55" Font-Bold="True" ForeColor="White" />
            <EditRowStyle BackColor="#7C6F57" />
            <AlternatingRowStyle BackColor="White" />
     </asp:GridView>

ありがとうございました

4

3 に答える 3

0

autogeneratefields をオフにして、セクションに表示するフィールドをリストします。

于 2013-04-15T18:02:49.247 に答える
0

まず、AutoGenerateColumnsプロパティを次のように設定しますFalse

Private Sub GridView_RowDataBound(ByVal sender As System.Object,ByVal e As System.GridViewRowEventArgs )
{
  e.Row.Cells("PK").Visible = False
}
于 2013-04-15T18:09:06.087 に答える