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 :

Modification de données par appel de fonction


Sujet :

ASP.NET

  1. #1
    Membre actif
    Homme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 220
    Points : 268
    Points
    268
    Par défaut Modification de données par appel de fonction
    Bonjour,

    J'ai un soucis avec la mise a jour de données:

    Lorsque je veux modifier des données en passant par un DetailsView tout fonctionne bien tant que je mets un contrôle dans mon EditItemTemplate et que je lui mets comme valeur Mais cette fois je récupère la date du jour et le nom d'utilisateur connecté à traveres une fonction qui me retourne un string: la concaténation des deux.

    Lors du click sur le lien "modifier" du DetailsView mon Label se met à jour correctement avec la valeur de ma fonction mais si je click sur "mettre à jour" ca ne fonctionne pas...

  2. #2
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2009
    Messages
    229
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2009
    Messages : 229
    Points : 305
    Points
    305
    Par défaut
    Avec juste cette message on peut pas voir grande chose , publie ton code

  3. #3
    Membre actif
    Homme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 220
    Points : 268
    Points
    268
    Par défaut
    Effectivement ce serait plus parlant avec le code..

    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
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    <asp:DetailsView ID="DetailsView1" runat="server" Height="16px" Width="400px" 
                AutoGenerateEditButton="True" AutoGenerateRows="False" 
                DataSourceID="RechercheArticle" BackColor="White" BorderColor="#999999" 
                BorderStyle="None" BorderWidth="1px" CellPadding="3" GridLines="Vertical" 
                HorizontalAlign="Center" style="margin-left: 0px; margin-right: 0px">
     
                <AlternatingRowStyle BackColor="#DCDCDC" />
                <EditRowStyle BackColor="#CCCCCC" Font-Bold="True" ForeColor="Black" 
                    Width="150px" />
     
                <Fields>
     
                    <asp:TemplateField HeaderText="ID Article">
                        <ItemTemplate>
                            <asp:Label ID="LabelIdArticle" runat="server" Text='<%# Eval("ID_Article") %>'></asp:Label>
                        </ItemTemplate>
     
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Nom Article">
                        <ItemTemplate>            
                            <asp:Label ID="LabelNomArticle" runat="server" Text='<%# Eval("Nom_Article") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Famille du Produit">
                        <ItemTemplate>
                            <asp:Label ID="LabelFamille" runat="server" Text='<%# Eval("Famille_Produit") %>'></asp:Label>
                        </ItemTemplate>
     
                        <EditItemTemplate>                       
                        </EditItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Sous-famille du Produit">
                        <ItemTemplate>
                            <asp:Label ID="LabelSousFamille" runat="server" Text='<%# Eval("Sous_Famille_Produit") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Quantite annuelle utilisée">
                        <ItemTemplate>
                            <asp:Label ID="LabelQuantiteUtilisee" runat="server" Text='<%# Eval("Quantite_Utilisee") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Unité de stockage">
                        <ItemTemplate>
                            <asp:Label ID="LabelUniteStockage" runat="server" Text='<%# Eval("Unite_Stockage") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Fiche De Sécurité (FDS)">
                        <ItemTemplate>
                            <asp:CheckBox ID="CheckBoxFDS" runat="server" Checked='<%# Bind("FDS") %>' 
                                Enabled="false" />
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Date FDS">
                        <ItemTemplate>
                            <asp:Label ID="LabelDateFDS" runat="server" Text='<%# Eval("Date_FDS") %>'></asp:Label>
                        </ItemTemplate>
     
                        <EditItemTemplate>
                            <asp:Calendar ID="Calendar1" runat="server" 
                                onselectionchanged="Calendar1_SelectionChanged" 
                                SelectedDate='<%# Bind("Date_FDS") %>' BackColor="White" 
                                BorderColor="#999999" CellPadding="4" DayNameFormat="Shortest" 
                                Font-Names="Verdana" Font-Size="8pt" ForeColor="Black" Height="180px" 
                                Width="200px" >
                                <DayHeaderStyle BackColor="#CCCCCC" Font-Bold="True" Font-Size="7pt" />
                                <NextPrevStyle VerticalAlign="Bottom" />
                                <OtherMonthDayStyle ForeColor="#808080" />
                                <SelectedDayStyle BackColor="#666666" Font-Bold="True" ForeColor="White" />
                                <SelectorStyle BackColor="#CCCCCC" />
                                <TitleStyle BackColor="#999999" BorderColor="Black" Font-Bold="True" />
                                <TodayDayStyle BackColor="#CCCCCC" ForeColor="Black" />
                                <WeekendDayStyle BackColor="#FFFFCC" />
                            </asp:Calendar>
                        </EditItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Date de Modification">
                        <EditItemTemplate>
                            <asp:TextBox ID="TextBox2" runat="server" Text='<%# Bind("Date_Modif") %>'></asp:TextBox> <!-- C'est ici que ca pose problème, je voudrais que ma TextBox prenne la valeur de ma fonction --!>
                        </EditItemTemplate>
                        <ItemTemplate>
                            <asp:Label ID="LabelDateModif" runat="server" Text='<%# Eval("Date_Modif") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Date de Validation FDS">
                        <ItemTemplate>
                            <asp:Label ID="LabelDateValid" runat="server" Text='<%# Eval("Date_Validation_FDS") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Solvant">
                        <ItemTemplate>
                            <asp:CheckBox ID="CheckBoxSolvant" runat="server" Checked='<%# Bind("Solvant") %>' 
                                Enabled="false" />
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Pression Vapeur">
                        <ItemTemplate>
                            <asp:Label ID="LabelPressionVapeur" runat="server" Text='<%# Eval("Pression_Vapeur") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Quantité max. de Stockage">
                        <ItemTemplate>
                            <asp:Label ID="LabelQuantiteStockage" runat="server" Text='<%# Eval("Quantite_Max_Stock") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Fréquence d'utilisation">
                        <EditItemTemplate>
                            <asp:TextBox ID="TextBox1" runat="server" 
                                Text='<%# Bind("Frequence_Utilisation") %>'></asp:TextBox>
                        </EditItemTemplate>
                        <ItemTemplate>
                            <asp:Label ID="LabelFrequenceUtilisation" runat="server" Text='<%# Eval("Frequence_Utilisation") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Risque Potentiel">
                        <ItemTemplate>
                            <asp:Label ID="LabelRisquePotentiel" runat="server" Text='<%# Eval("Risque_Potentiel") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                     <asp:TemplateField HeaderText="Priorité">
                        <EditItemTemplate>
                            <asp:DropDownList ID="DropDownList2" runat="server" 
                                SelectedValue='<%# Bind("Priorite") %>' DataSourceID="Priorite" 
                                DataTextField="Priorite" DataValueField="Priorite">
                            </asp:DropDownList>
                            <asp:SqlDataSource ID="Priorite" runat="server" 
                                ConnectionString="<%$ ConnectionStrings:prodchimiquesConnection %>" 
                                SelectCommand="SELECT [Priorite] FROM [Article]"></asp:SqlDataSource>
                        </EditItemTemplate>
                        <ItemTemplate>
                            <asp:Label ID="LabelPriorite" runat="server" Text='<%# Eval("Priorite") %>'></asp:Label>
                        </ItemTemplate>
     
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Etat du Stock">
                        <ItemTemplate>
                            <asp:Label ID="LabelEtatStock" runat="server" Text='<%# Eval("Stock") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                    <asp:TemplateField HeaderText="Commentaire">
                        <ItemTemplate>
                            <asp:Label ID="LabelCommentaire" runat="server" Text='<%# Eval("Commentaire") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
     
                </Fields>
     
                <FooterStyle BackColor="#CCCCCC" ForeColor="Black" />
                <HeaderStyle BackColor="#000084" Font-Bold="True" ForeColor="White" />
                <PagerStyle BackColor="#999999" ForeColor="Black" HorizontalAlign="Center" />
                <RowStyle BackColor="#EEEEEE" ForeColor="Black" Width="300px" />
        </asp:DetailsView>

    Donc mon soucis se trouve au niveau du commentaire, si à la place de Bind("Date_Modif") je mets MaFonction() j'ai une erreur qui me dit que le champ Date_Modif ne peut être null...
    J'ai essayé de passer par un évenement du DetailsView mais je n'arrive pas à modifier même en faisant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (TextBox)DetailsView1.FindControl("TextBox2").Text = MaFonction
    Il aime pas le .Text après FindControl..

  4. #4
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2009
    Messages
    229
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2009
    Messages : 229
    Points : 305
    Points
    305
    Par défaut
    Il faut que tu implémente la méthode OnItemUpdated de ta DetailsView. Et dedans, tu change la valeur de textbox.
    Càd, dans le code de OnItemUpdated, tu met :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    (TextBox)DetailsView1.FindControl("TextBox2").Text = MaFonction
     et ensuite Bind ta DetailsView

  5. #5
    Membre actif
    Homme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 220
    Points : 268
    Points
    268
    Par défaut
    Là est le problème,
    Le Après
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DetailsView1.FindControl("TextBox2")
    Ne passe pas
    Il me sort ceci:
    Erreur 1 'System.Web.UI.Control' ne contient pas une définition pour 'Text' et aucune méthode d'extension 'Text' acceptant un premier argument de type 'System.Web.UI.Control' n'a été trouvée (une directive using ou une référence d'assembly est-elle manquante*?) c:\inetpub\wwwroot\ProdChimiques\Produits.aspx.cs 122 55 http://localhost/ProdChimiques/
    J'ai essayé une alternative qui ne passe pas non plus:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
            TextBox txtb = new TextBox();
            txtb.Text = modifie();
            (TextBox)DetailsView1.FindControl("TextBox2") = txtb;
    qui cette fois me donne cette erreur:
    Erreur 2 La partie gauche d'une assignation doit être une variable, une propriété ou un indexeur c:\inetpub\wwwroot\ProdChimiques\Produits.aspx.cs 129 10 http://localhost/ProdChimiques/

  6. #6
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2009
    Messages
    229
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2009
    Messages : 229
    Points : 305
    Points
    305
    Par défaut
    Voici, tu implémente la méthode OnItemInserted="InsertedDetailsView" de DetailsView.
    Par la suite dans le code de cette méthode, tu mis à jour le TextBox :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    protected void InsertedDetailsView(object sender, DetailsViewInsertedEventArgs e)
            {
                TextBox myTextBoxToUpdate = (TextBox) DetailsView1.Rows[e.AffectedRows].FindControl("TextBox");
                myTextBoxToUpdate.Text = MaFonction; 
            }

  7. #7
    Membre actif
    Homme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 220
    Points : 268
    Points
    268
    Par défaut
    En fait dans l'évenement onUpdating du DetailsView il faut modifier la valeur du paramêtre de la méthode Update du SqlDataSource:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
        protected void DetailsView1_ItemUpdating(object sender, DetailsViewUpdateEventArgs e)
        {
            e.NewValues[3] = modifie();
        }
    NewValues[3] dis donc que le 3ème paramêtre de la méthode Update du SqlDataSource doit prendre la valeur de ma fonction modifie().

    Voila pour les prochains.

    Mais entre temps je suis passé à un formulaire complet, on contrôle plus facilement ce qu'il se passe.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 8
    Dernier message: 08/12/2011, 17h54
  2. generation de fonction par appel de fonction
    Par alx4t1 dans le forum MATLAB
    Réponses: 1
    Dernier message: 29/08/2011, 22h22
  3. [AJAX] Vérification données par appel AJAX
    Par richard_sraing dans le forum AJAX
    Réponses: 10
    Dernier message: 25/03/2011, 15h58
  4. Réponses: 10
    Dernier message: 05/03/2007, 14h55
  5. modifications de données par lot
    Par pracolas dans le forum Access
    Réponses: 16
    Dernier message: 03/02/2007, 14h13

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