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

jQuery Discussion :

Ajax form et attribut action


Sujet :

jQuery

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 38
    Points : 24
    Points
    24
    Par défaut Ajax form et attribut action
    Bonjour,

    J'ai un problème que je n'arrive pas à résoudre. Je dois récupérer l'action dans un form, le réécrire puis soumettre le formulaire en ajax.

    Actuellement j'ai plusieurs pistes :

    Methode 1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    	$(".btnmain").click(function(){
     
    		$('form').attr("action", function(){
    		this.action = $('form').attr('action');
    		this.action = this.action.replace(/\/$/, "");
    		this.action = this.action.replace("fobb/", "");
    		this.action = this.action.replace(".php", "");
     
    			});
    		//return false;
    	});
    Le comportement fonctionne mais l'ajax n'est pas implémenté.

    Methode 2
    Mais ceci ne marche pas -> (ajax non lançé)

    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
    	$(".btnmain").click(function(){
     
    		$('form').attr("action", function(){
    		this.action = $('form').attr('action');
    		this.action = this.action.replace(/\/$/, "");
    		this.action = this.action.replace("fobb/", "");
    		this.action = this.action.replace(".php", "");
     
    		$.post(this.action ,$('form').serialize(), function(data){
    			$('#layout').html(data);
     
    		  });
     
    			});
    		return false;
    	});
    Methode 3
    ou encore, sans succes (ajax lançé mais le php retourne de mauvais résultat) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    	$(".btnmain").click(function(){
    		var myaction = $('form').attr('action');
    		myaction = myaction.replace(/\/$/, "");
    		myaction = myaction.replace("fobb/", "");
    		myaction = myaction.replace(".php", "");
    		$.post(myaction,$('form').serialize(), function(data){
    			$('#layout').html(data);
     
    			});
     
    		return false;
     
    	});
    });
    Comment pourrais je fusionner la Méthode 1 et la méthode 3 ?

  2. #2
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 640
    Points : 66 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut
    c'est quoi ton .btnmain ?

    on peut voir le html du form?

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 38
    Points : 24
    Points
    24
    Par défaut
    le .btmain c'est la class du bouton submit. Je ne peux pas toucher le html donc impossible de le modifier, il faut exploiter ce que l'on à ^^

    Le form est trés gros donc si je fais un copié collé ça vas pas le faire, en voici donc juste un bout :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <form enctype="multipart/form-data" name="postform" method="post" action="fobb/posting.php?mode=post&amp;f=2">
     
     
    <input type="hidden" value="1314786162" name="lastclick">
    <input type="submit" value="Prévisualisation" name="preview" tabindex="10" class="btnlite">
    <input type="submit" value="Envoyer" name="post" tabindex="11" accesskey="s" class="btnmain">
    <input type="submit" value="Annuler" name="cancel" tabindex="14" accesskey="c" class="btnlite">
    <input type="hidden" value="1314786162" name="creation_time">
    <input type="hidden" value="f20af6c5166236137100adead8c5d6e3344323fd" name="form_token">
     
    	</form>

  4. #4
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 640
    Points : 66 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut
    je en comprends pas la liaison que tu fais au niveua du fait que php ne retourne pas le bon resultat ? c'est independant de javascript ...

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 38
    Points : 24
    Points
    24
    Par défaut
    Si, car dans le cas présent le php attendait la valeur post "Envoyer" que traite le bouton submit dans un comportement normal. Hors dans la méthode que j'essayais, elle était extrapolé par le javascript donc le traitement php ne se faisait pas ^^

    J'ai devais donc rajouter un input hidden "post" value "envoyer" mais comme je ne peux modifier le html je l'ais rajouter avec le javascript. Ce qui fonctionne, mais si y'a une méthode moins lourde je suis preneur.

    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
    	$(".btnmain").click(function(){
    		var myaction = $('form').attr('action');
    		myaction = myaction.replace(/\/$/, "");
    		myaction = myaction.replace("fobb/", "");
    		myaction = myaction.replace(".php", "");
    		$.post(myaction, wrapFormValues('form'), function(data){
    			$('#layout').html(data);
     
    			});
     
    		return false;
     
    	});
    });
     
    function wrapFormValues(form) { 
     
        form = $(form).serializeArray();
        var dataArray = new Object();
     
        for( index in form)
        {   
            if(form[index].value)   {
                    dataArray[form[index].name] = form[index].value;        
            }
        }   
        dataArray['post'] = 'Envoyer';  
        return dataArray; 
    }

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

Discussions similaires

  1. [Débutant] Attribut action d'un form runat="server"
    Par rokirakat dans le forum ASP.NET
    Réponses: 4
    Dernier message: 12/10/2011, 16h52
  2. Caractère # dans l'attribut action d'un form
    Par miltone dans le forum Balisage (X)HTML et validation W3C
    Réponses: 17
    Dernier message: 07/08/2011, 16h41
  3. Modifier l'attribut "ACTION" de la balise "FORM"
    Par Alex35 dans le forum ASP.NET
    Réponses: 1
    Dernier message: 08/10/2009, 14h17
  4. [3.5] modification attribut action du form de la page
    Par CUCARACHA dans le forum ASP.NET
    Réponses: 1
    Dernier message: 02/10/2008, 09h17
  5. l'attribut ACTION dans la balise FORM
    Par coco-sup dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 23/02/2007, 12h02

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