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

Bibliothèques & Frameworks Discussion :

Serialize multiple submit [Prototype]


Sujet :

Bibliothèques & Frameworks

  1. #1
    Membre régulier
    Inscrit en
    Mars 2006
    Messages
    126
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 126
    Points : 105
    Points
    105
    Par défaut Serialize multiple submit
    Bonjour,

    J'utilise prototype, et j'ai un problème avec un formulaire qui contient plusieurs boutons sumbit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    			<input type="submit" name="submit" value="Ajouter">
    			<input type="submit" name="submit" value="Modifier">
    			<input type="submit" name="submit" value="Supp">
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    	function ValidateFormCash(result,form){
    		if(result){
    			var params = Form.serialize($('saisie'));
    			alert(params);
    			new Ajax.Request('ajax/cash.php', {onComplete:handlerFuncSaisie,onFailure:errFunc,asynchronous:true,parameters:params});
    		}
    	}
     
    	var valid = new Validation('saisie', {immediate : true, onFormValidate : ValidateFormCash});
    A chaque validation du formulaire, la variable submit contient toujours "Ajouter" quelque soit le bouton sur lequel on a appuyé.

    Quelqu'un a t'il une idée ?
    Merci

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Ben... trois boutons submit sur un formulaire... ça en fait pas deux de trop ???

  3. #3
    Membre régulier
    Inscrit en
    Mars 2006
    Messages
    126
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 126
    Points : 105
    Points
    105
    Par défaut
    Les 3 boutons n'ont pas la même fonctionnalités.

  4. #4
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <input type="submit" name="submit" value="Ajouter">
    			<input type="submit" name="submit" value="Modifier">
    			<input type="submit" name="submit" value="Supp">
    A part value (dont le seul rôle est de mettre du texte dans le bouton), ils font exactement la même chose (un submit du formulaire...)

  5. #5
    Membre régulier
    Inscrit en
    Mars 2006
    Messages
    126
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 126
    Points : 105
    Points
    105
    Par défaut
    Oui mais en récupérant la valeur (value) je peux savoir sur quel bouton la personne a cliqué et ainsi faire un traitement différent selon.

    Mais j'imagine que tu dois avoir une autre méthode ? J'achète !!!!

  6. #6
    Nouveau membre du Club
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2006
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Août 2006
    Messages : 40
    Points : 39
    Points
    39
    Par défaut
    Envoie le code de ton formulaire, je pense que c'est plutôt là qu'il te faudra changer certains trucs...

  7. #7
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Oui mais en récupérant la valeur (value) je peux savoir sur quel bouton la personne a cliqué et ainsi faire un traitement différent selon.
    Si c'était le cas, tu n'aurais pas de problème...
    Un formulaire = un submit...
    Mais j'imagine que tu dois avoir une autre méthode ? J'achète !!!!
    Au lieu de mettre 3 boutons submit, mets plutôt 3 boutons :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <input type="button" value="valeur" onclick="traitement(this.value)" />
    voire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <input type="button" value="valeur" onclick="traitement('valeur')" />
    puis la fonction javascript traitement qui te permet de savoir quel bouton a été cliqué, traiter en conséquence et finir par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.forms[nom_du_formulaire].submit();
    Vendu !!!

  8. #8
    Membre régulier
    Inscrit en
    Mars 2006
    Messages
    126
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 126
    Points : 105
    Points
    105
    Par défaut
    Merci bien !
    Ca marche mieux comme ça !!

    (désolé pour les remerciements tardifs

  9. #9
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    De rien c'est toujours sympa d'y penser

  10. #10
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2009
    Messages
    383
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2009
    Messages : 383
    Points : 658
    Points
    658
    Par défaut
    Bonjour tout le monde;

    Bon, je resors un vieux post... j'avoue mais c'est pour profiter des différentes interventions et proposer une réflexion un peu différente.

    Dans un formulaire classique sans javascript, le fait d'utiliser plusieurs submit dans un formulaire permet de récupérer en POST la variable du bouton qui est actionné.
    Dans l'exemple mentionné par notre ami Hesiode, la variable POST aurait la valeur Ajouter ou Modifier selon le bouton; et ce, sans javascript.

    Avec Form.serialize, horreur, ca ne marche pas... il en prend que un des deux.

    Alors, je propose une solution pour ceux qui tomberait sur cette page et que cela intéresserait. (basé sur prototype toujours...)

    A l'initialisation, on modifie le onclick des submits contenus dans le formulaire.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    form.getInputs('submit').each(function(submitInput){
    	submitInput._submitted = false;
    	submitInput.onclick = function(){
    		submitInput._submitted = true;
    	}.bind(this);
    }.bind(this));
    Cette premiere partie de code permet l'application d'un flag "_submitted" sur le submit qui soumet le formulaire.

    Ensuite, vous devinez (en reprenant l'exemple original).
    Au moment du submit, on check dans les submits contenus dans la form lequel contient le flag à vrai...
    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
     
    form.onsubmit = function(){
    	var params = Form.serialize($('saisie'));
     
    	var submitValue = {};
    	form.getInputs('submit').each(function(submitInput){
    		if (submitInput._submitted === true){
    			submitValue[ submitInput.name ] = submitInput.value;
    		}
    		submitInput._submitted = false;
    	}.bind(this));
    	Object.extend( formOptions , submitValue || {} );
     
     
    	new Ajax.Request('ajax/cash.php', {onComplete:handlerFuncSaisie,onFailure:errFunc,asynchronous:true,parameters:params});
     
    }
    (un truc du genre)

    Voici...

    Le but principal de cette méthode est de garder le fonctionnement identique qu'on utilise ou non javascript.

    Je suis ouvert aux commentaires et critiques constructives.

    Cordialement

    Cédric

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

Discussions similaires

  1. [AJAX] Multiple submit et .load()
    Par soohikei dans le forum jQuery
    Réponses: 3
    Dernier message: 10/08/2014, 11h32
  2. [AJAX] Multiple Submit avec ajax
    Par perace dans le forum AJAX
    Réponses: 3
    Dernier message: 01/06/2011, 13h53
  3. Multiples submit sous IE6
    Par Franckintosh dans le forum Balisage (X)HTML et validation W3C
    Réponses: 7
    Dernier message: 23/11/2006, 22h23
  4. [Upload] upload fichiers avec multiple submit
    Par dolf13 dans le forum Langage
    Réponses: 17
    Dernier message: 06/06/2006, 01h20
  5. formulaire a multiple submit
    Par phoeniix07 dans le forum Langage
    Réponses: 5
    Dernier message: 31/05/2006, 10h59

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