IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

ASP.NET Discussion :

Masquer une colonne dans une datagrid


Sujet :

ASP.NET

  1. #1
    Membre régulier
    Avatar de unix27
    Inscrit en
    Septembre 2003
    Messages
    338
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Septembre 2003
    Messages : 338
    Points : 106
    Points
    106
    Par défaut Masquer une colonne dans une datagrid
    salut j'ai une datagrid composer de 3 champs(juste pour le test) et je souhaiterai masquer la 3 colonneonc briévement
    le code de la datagrid est:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
     
    <asp:GridView ID="GridView1" runat="server" DataKeyNames="Iddocument" 
                onselectedindexchanged="GridView1_SelectedIndexChanged">
            <Columns>
     
     
            <asp:TemplateField HeaderText="Selection" >
                    <EditItemTemplate>
                        <asp:TextBox ID="TextBox1" runat="server" Text='<%# Bind("Image") %>'></asp:TextBox>
                    </EditItemTemplate>
                    <ItemTemplate>
                        <asp:CheckBox ID="CheckBox2" runat="server"  Enabled="True" />
                    </ItemTemplate>
                </asp:TemplateField>
     
            <asp:CommandField   SelectImageUrl="~/icon_pdf.gif"  ShowSelectButton="True" />
     
                <asp:TemplateField HeaderText="Iddocument" InsertVisible="False" 
                    SortExpression="Iddocument" Visible="False">
                       <ItemTemplate>
                        <asp:Label ID="Label1" runat="server" Text='<%# Bind("Iddocument") %>'></asp:Label>
                    </ItemTemplate>
                </asp:TemplateField>
     
            </Columns>
            </asp:GridView>
    Le code C# est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
     
    protected void Button1_Click(object sender, EventArgs e)
        {
            List<Document> lstDocument = new List<Document>();
            Document doc;
     
     
            //1 element
            doc = new Document();
            doc.Iddocument = "12";
            doc.Image = "img1";
            lstDocument.Add(doc);
            //2 element
            doc = new Document();
            doc.Iddocument = "13";
            doc.Image = "img13";
            lstDocument.Add(doc);
     
     
     
            GridView1.DataSource = lstDocument;
            GridView1.Columns[2].Visible = false;
            GridView1.DataBind();
        }
    Donc on résumer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    GridView1.Columns[2].Visible = false;
    ca ne marche pas

  2. #2
    Membre expérimenté Avatar de Arthis
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    1 265
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : Italie

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 265
    Points : 1 352
    Points
    1 352
    Par défaut
    et un :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    magridview.Columns.Remove(macolonne)
    ne marcherait pas non plus?

  3. #3
    Membre régulier
    Avatar de unix27
    Inscrit en
    Septembre 2003
    Messages
    338
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Septembre 2003
    Messages : 338
    Points : 106
    Points
    106
    Par défaut
    Salut j'ai ajouté
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    GridView1.Columns.Remove("Iddocument");
    message d'erreur:
    Argument '1': impossible de convertir de 'string' en 'System.Web.UI.WebControls.DataControlField'

  4. #4
    Membre expérimenté Avatar de Arthis
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    1 265
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : Italie

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 265
    Points : 1 352
    Points
    1 352
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    GridView1.Columns.Remove(monfield)
    n'attends pas un string, fais un petit effort..

  5. #5
    Membre régulier
    Avatar de unix27
    Inscrit en
    Septembre 2003
    Messages
    338
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Septembre 2003
    Messages : 338
    Points : 106
    Points
    106
    Par défaut
    Je sais bien elle attend un System.Web.UI.WebControls.DataControlField
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    <asp:TemplateField HeaderText="Iddocument" InsertVisible="False" 
                    SortExpression="Iddocument" Visible="False">
                       <ItemTemplate>
                        <asp:Label ID="Label1" runat="server" Text='<%# Bind("Iddocument") %>'></asp:Label>
                    </ItemTemplate>
                </asp:TemplateField>
    quel est le nom du DataControlField :
    j'ai tout essayé: Label1, Iddocument mais ça marche pas

  6. #6
    Membre expérimenté Avatar de Arthis
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    1 265
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : Italie

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 265
    Points : 1 352
    Points
    1 352
    Par défaut
    et comem ca par exemple ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    GridView1.Columns.Remove(GridView1.Columns[3]);

  7. #7
    Membre régulier
    Avatar de unix27
    Inscrit en
    Septembre 2003
    Messages
    338
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Septembre 2003
    Messages : 338
    Points : 106
    Points
    106
    Par défaut
    ça ne marche pas Donc pour récapituler:
    La grid:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
     
    <asp:GridView ID="GridView1" runat="server" DataKeyNames="Iddocument" 
                onselectedindexchanged="GridView1_SelectedIndexChanged">
            <Columns>
     
     
            <asp:TemplateField HeaderText="Selection" >
                    <EditItemTemplate>
                        <asp:TextBox ID="TextBox1" runat="server" Text='<%# Bind("Image") %>'></asp:TextBox>
                    </EditItemTemplate>
                    <ItemTemplate>
                        <asp:CheckBox ID="CheckBox2" runat="server"  Enabled="True" />
                    </ItemTemplate>
                </asp:TemplateField>
     
            <asp:CommandField   SelectImageUrl="~/icon_pdf.gif"  ShowSelectButton="True" />
     
                <asp:TemplateField HeaderText="Iddocument" InsertVisible="False" 
                    SortExpression="Iddocument" Visible="False">
                    <%-- 
                    <EditItemTemplate>
                        <asp:Label ID="Label1" runat="server" Text='<%# Eval("Iddocument") %>'></asp:Label>
                    </EditItemTemplate>
                    --%>
                    <ItemTemplate>
                        <asp:Label ID="Iddocument" runat="server" Text='<%# Bind("Iddocument") %>'></asp:Label>
                    </ItemTemplate>
                </asp:TemplateField>
     
            </Columns>
            </asp:GridView>
    l'appel Onclick
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     GridView1.DataSource = lstDocument;
       GridView1.Columns.Remove(GridView1.Columns[2]);
            GridView1.DataBind();

  8. #8
    Rédacteur
    Avatar de lutecefalco
    Profil pro
    zadzdzddzdzd
    Inscrit en
    Juillet 2005
    Messages
    5 052
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : zadzdzddzdzd

    Informations forums :
    Inscription : Juillet 2005
    Messages : 5 052
    Points : 8 734
    Points
    8 734
    Par défaut
    et ça?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    GridView1.DataSource = lstDocument;
            GridView1.DataBind();
            GridView1.Columns[2].Visible = false;

  9. #9
    Membre régulier
    Avatar de unix27
    Inscrit en
    Septembre 2003
    Messages
    338
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Septembre 2003
    Messages : 338
    Points : 106
    Points
    106
    Par défaut
    je l'est essayé en premier et ça ne marche pas

  10. #10
    Membre expérimenté Avatar de Arthis
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    1 265
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : Italie

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 265
    Points : 1 352
    Points
    1 352
    Par défaut
    non tu as essayé l'inverse de ce que LuteceFalco te propose!

  11. #11
    Membre régulier
    Avatar de unix27
    Inscrit en
    Septembre 2003
    Messages
    338
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Septembre 2003
    Messages : 338
    Points : 106
    Points
    106
    Par défaut
    Salut, ça ne marche pas non plus

  12. #12
    Membre expérimenté Avatar de Arthis
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    1 265
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : Italie

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 265
    Points : 1 352
    Points
    1 352
    Par défaut
    Cela provient forcement de ta page et du cycle de vie de tes objets, de tes bindings, creation d'objets etc...

    la page suivante montre quatre colonne et en cache une quand on appuie sur le bouton :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
     
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head runat="server">
        <title></title>
    </head>
    <body>
        <form id="form1" runat="server">
        <div>
            <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" 
                DataKeyNames="Id" DataSourceID="SqlDataSource1" 
                onselectedindexchanged="GridView1_SelectedIndexChanged">
                <Columns>
                    <asp:BoundField DataField="Id" HeaderText="Id" InsertVisible="False" 
                        ReadOnly="True" SortExpression="Id" />
                    <asp:BoundField DataField="Username" HeaderText="Username" 
                        SortExpression="Username" />
                    <asp:BoundField DataField="Password" HeaderText="Password" 
                        SortExpression="Password" />
     
                    <asp:BoundField DataField="CreationDate" HeaderText="CreationDate" 
                        SortExpression="CreationDate" />
                        <asp:CommandField  ShowSelectButton="True" />
                </Columns>
            </asp:GridView>
            <asp:SqlDataSource ID="SqlDataSource1" runat="server" 
                ConnectionString="<%$ ConnectionStrings:dynamiqVotingConnectionString %>" 
                SelectCommand="SELECT [Id], [Username], [Password], [CreationDate] FROM [T_AdminUsers]"></asp:SqlDataSource>
        </div>
        </form>
    </body>
    </html>

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.UI;
    using System.Web.UI.WebControls;
     
    public partial class Default2 : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
     
        }
        protected void GridView1_SelectedIndexChanged(object sender, EventArgs e)
        {
            GridView1.Columns.Remove(GridView1.Columns[3]);
        }
    }

  13. #13
    Membre régulier
    Avatar de unix27
    Inscrit en
    Septembre 2003
    Messages
    338
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Septembre 2003
    Messages : 338
    Points : 106
    Points
    106
    Par défaut
    salut mais mais je n'effectue qu'un seule binding donc normalement ça devrai marcher mais bon merci pour ton exemple mais le souci persiste toujours

  14. #14
    Membre régulier
    Avatar de unix27
    Inscrit en
    Septembre 2003
    Messages
    338
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Septembre 2003
    Messages : 338
    Points : 106
    Points
    106
    Par défaut
    je n'es toujours pas trouvé la solution même si ça paraît simple

  15. #15
    Expert éminent
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Points : 9 512
    Points
    9 512
    Par défaut
    Salut,

    Apparement sur le net on utilise plutôt la visiblité des cellules pour cacher une colonne. Il faut cacher la cellule sur l'evenement de création de la ligne. Une recherche avec sur "gridview columns visible" donne des resultats en ce sens.

    A+

  16. #16
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    923
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 923
    Points : 760
    Points
    760
    Par défaut
    Bonjour à tous,

    Après beaucoup chercher, j'ai trouvé ce lien


    J'espere qu'il vous aide.

Discussions similaires

  1. Réponses: 7
    Dernier message: 25/03/2011, 10h52
  2. Réponses: 4
    Dernier message: 05/05/2008, 15h16
  3. Récupérer le nom d'une colonne d'une table dans une variable
    Par mimi51340 dans le forum Général Java
    Réponses: 4
    Dernier message: 13/03/2008, 14h23
  4. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48
  5. Insérer par programmation une valeur dans une colonne d'un Datagrid.
    Par Jean_dick15 dans le forum Windows Forms
    Réponses: 4
    Dernier message: 12/04/2007, 15h32

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo