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 :

Contenu d'une listbox non récupéré sur Postback


Sujet :

ASP.NET

  1. #1
    Membre averti
    Profil pro
    Chef-balayeur
    Inscrit en
    Octobre 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef-balayeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 28
    Par défaut Contenu d'une listbox non récupéré sur Postback
    Bonsoir,

    Jusqu'à maintenant, lorsque, sur une page ASP .Net, je devais transférer des éléments d'une listbox dans une autre, ça se faisait via un bouton qui provoquait un postback, donc avec un A/R Serveur.

    Pour éviter cette sollicitation inutile du serveur, j'ai voulu m'amuser avec jQuery et utiliser cette librairie pour faire ça côté client.
    Ça marche nickel pour ce qui est de l'aspect visuel : ma liste cible contient bien les éléments que j'ai piochés dans la liste source.

    Le seul blème, et il est de taille, c'est que lorsque je clique sur le bouton de validation de ma page, ma listbox cible, vue côté serveur, est vide ou contient uniquement les éléments avec laquelle je l'avais initialisée, mais pas les éléments ajoutés côté client.

    Je suppose que je commets une méga-bévue de débutant, mais je ne vois absolument pas laquelle.

    Si une bonne âme pouvait me mettre sur une piste, ça m'ôterait une sacré épine du pied.

    Merci d'avance.

    Lino.

  2. #2
    Membre émérite Avatar de Ramajb
    Homme Profil pro
    ----------------------------
    Inscrit en
    Septembre 2007
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ----------------------------

    Informations forums :
    Inscription : Septembre 2007
    Messages : 476
    Par défaut
    Pour éviter cette sollicitation inutile du serveur, j'ai voulu m'amuser avec jQuery et utiliser cette librairie pour faire ça côté client.
    Donc tu es de cote client. ( le serveur n'est pas au courant )

    Le seul blème, et il est de taille, c'est que lorsque je clique sur le bouton de validation de ma page, ma listbox cible, vue côté serveur, est vide ou contient uniquement les éléments avec laquelle je l'avais initialisée, mais pas les éléments ajoutés côté client.
    Si tu as fais uniquement une manipulation javascript de cote client, c'est normal que tu aies ce bleme.

  3. #3
    Membre averti
    Profil pro
    Chef-balayeur
    Inscrit en
    Octobre 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef-balayeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 28
    Par défaut
    Donc tu es de cote client. ( le serveur n'est pas au courant )
    Jusque là, c'était bien mon but (je souhaite éviter des A/R serveur inutiles alors que le transfert d'une listbox vers une autre peut se faire côté client) et je ne comprends donc pas la remarque.

    Si tu as fais uniquement une manipulation javascript de cote client, c'est normal que tu aies ce bleme
    Là, faut m'expliquer.
    Mon contrôle listbox cible est chargé avec les éléments que j'y ai ajouté. Lorsque je clique sur mon bouton de validation, le contenu ou l'état des contrôles, quels qu'ils soient, est normalement envoyé vers le serveur qui n'a plus qu'à les récupérer (en tous cas que ce soit avec ASP ou PHP, que je pratique aussi depuis bien plus longtemps, ça marche parfaitement).
    Pourquoi est-ce que ça ne serait pas le cas avec ASP .Net ?

  4. #4
    Membre émérite Avatar de Ramajb
    Homme Profil pro
    ----------------------------
    Inscrit en
    Septembre 2007
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ----------------------------

    Informations forums :
    Inscription : Septembre 2007
    Messages : 476
    Par défaut
    Là, faut m'expliquer.
    Quand tu ajoutes des nouveaux éléments dans un DropDownList ou ListBox de cote serveur, ton viewstate se souvient uniquement des ces éléments avant de les envoyés vers le client.
    Maintenant quand tu ajoutes des nouveaux éléments de coté client, et une fois que tu fasses un postback, le contrôle sera recrée et le serveur utilise le contenu du ViewState pour rétablir l'etat du control ( donc avec les données existant auparavant, mais sans les nouveaux éléments rajoutés de cote client donc).
    Une solution, si tu ne veux pas avoir un flash lors de l'ajout d’élément de cote client, tu peut utiliser Ajax (mais derrière y a tjs un A/R serveur sans que l'utilisateur le remarque) ou encore au pire, créer un champ hidden et le mettre la dedans tous les nouveaux éléments ajoutés du coté client. Et une fois au serveur tu rajoute les nouveaux éléments.

    J’espère t'avoir aidé.

  5. #5
    Membre averti
    Profil pro
    Chef-balayeur
    Inscrit en
    Octobre 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef-balayeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 28
    Par défaut
    Merci pour ton éclairage.

    C'est exactement ce que je venais de comprendre via des forums en anglais et j'étais en train d'implémenter le coup du champ caché quand tu as posté ta réponse parfaitement limpide (quand on sait).
    Et quand on est habitué à PHP (ou l'ancien ASP), c'est très lourd, cette histoire.

    Mais j'aimerais quand même comprendre un truc :
    Pourquoi la mise à jour dynamique côté client d'un contrôle type textbox ou d'un champ caché, par exemple, est-elle bien reflétée côté serveur quand on valide (et c'est heureux !) et pas celle d'une listbox ?
    Il me semble y avoir quelque chose d'incohérent là-dedans.

  6. #6
    Membre émérite Avatar de Ramajb
    Homme Profil pro
    ----------------------------
    Inscrit en
    Septembre 2007
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ----------------------------

    Informations forums :
    Inscription : Septembre 2007
    Messages : 476
    Par défaut
    Mais j'aimerais quand même comprendre un truc :
    Pourquoi la mise à jour dynamique côté client d'un contrôle type textbox ou d'un champ caché, par exemple, est-elle bien reflétée côté serveur quand on valide (et c'est heureux !) et pas celle d'une listbox ?
    Il me semble y avoir quelque chose d'incohérent là-dedans.
    Exactement. En fait pour le TextBox c'est un peu différent . Mais ne me demande pas pourquoi on l'a fait ainsi . Remarque, même si tu fais EnableViewState=false pour un Textbox, il te ramène quand même une valeur après postback. Bref, TextBox n'utilise pas le ViewState pour faire persister une valeur, au lieu de ça il utilise l’entête du HTTP Post pour stocker la valeur. Une fois arrivé au serveur, precisement dans l'evenement LoadPostBackData, sa valeur se voit restituer à partir de l'entete du HTTP Post.

Discussions similaires

  1. [AC-2003] Afficher le contenu d'une listBox sur evenement après mise à jour d'une autre.
    Par moilou2 dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 17/07/2009, 11h47
  2. Réponses: 6
    Dernier message: 02/06/2006, 11h44
  3. Réponses: 1
    Dernier message: 27/05/2006, 23h13
  4. Réponses: 5
    Dernier message: 30/11/2005, 09h48
  5. Ouvrir une popup non redimensionnable sur clique
    Par magic8392 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 6
    Dernier message: 14/09/2005, 09h44

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