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

JavaScript Discussion :

[AJAX] Formulaire : POST


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    266
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 266
    Par défaut [AJAX] Formulaire : POST
    Bonjour, je me mets tout juste à AJAX et je suis les tutos de developpez.com (merci d'ailleurs).

    Dans mon cas je crée un formulaire à deux champs texte (pseudo et message), et je souhaite qu'à la validation, une fonction JavaScript envoie les données à une page .php (qui fera des requetes SQL plus tard) en mode POST. En retour de réponse du serveur j'affiche les données envoyées à la page .php dans une boite de dialogue.

    Mais pas de boite de dialogue qui s'affiche
    Je précise que ma fonction JavaScript est bien appelée.

    Voilà le code de la page contenant le formulaire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
                  <form method="post" onsubmit="checkPostLivreDor()" action="">
                    <p>Pseudo</p><br />
                    <input name="pseudo" id="id_pseudo" type="text" /><br /><br />
                    <p>Message</p><br />
                    <textarea rows="5" cols="70" name="message" id="id_message" type="text"></textarea><br /><br />
                    <input type="submit" value="Poster" />
                  </form>
    Celui de ma fonction JavaScript :
    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
     
    function checkPostLivreDor() {
        var xhr = getXhr();
        var pseudo = document.getElementById('id_pseudo');
        var message = document.getElementById('id_message');
        // Fonction de retour de réponse
        xhr.onreadystatechange = function() {
    		// On ne fait quelque chose que si on a tout reçu et que le serveur est ok
    		if(xhr.readyState == 4 && xhr.status == 200){
    		    alert(xhr.responseText);
    		}
    	}
        // Appel asynchrone
        xhr.open("POST", "/site/requetes/ajoutlivredor.php", true);
        xhr.send("pseudo=" + pseudo.value + "&message=" + message.value);
        return false;
    }
    Et enfin celui de la page ajoutlivredor.php qui fera plus tard des requetes SQL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    <?php
            echo "test !";
    ?>
    NB : débutant en AJAX, est-ce ici une bonne utilisation ?

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    266
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 266
    Par défaut
    Petite info supplémentaire :
    J'ai utilisé la méthode GET et ça marche mais seulement sous IE... pas sous Firefox

    Quelqu'un a une solution ?

  3. #3
    Membre éprouvé
    Profil pro
    Développeur Web
    Inscrit en
    Juillet 2007
    Messages
    112
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2007
    Messages : 112
    Par défaut
    En se calquant sur un cours developpez.com, on obtient le code suivant.

    Je ne saurai te dire pourquoi il y a un pb avec le onsubmit sur le form, mais vu que ton form est géré par ajax, autant ne pas faire de form

    Pour ton 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
    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
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
     
    <head>
    	<title>Exemple 4</title>
     
    	<script>
    function checkPostLivreDor()
    {
        var xhr=null;
     
        if (window.XMLHttpRequest) { 
            xhr = new XMLHttpRequest();
        }
        else if (window.ActiveXObject) 
        {
            xhr = new ActiveXObject("Microsoft.XMLHTTP");
        }
        //on définit l'appel de la fonction au retour serveur
        xhr.onreadystatechange = function() { alert_ajax(xhr); };
     
        //on appelle le fichier reponse.txt
        xhr.open("GET", "reponse.php", true);
        xhr.send("pseudo=" + document.getElementById("id_pseudo").value + "&message=" + document.getElementById("id_message").value);
    }
     
    function alert_ajax(xhr)
    {
    	var docXML= xhr.responseXML;
    	var items = docXML.getElementsByTagName("donnee")
    	//on fait juste une boucle sur chaque element "donnee" trouvé
    	for (i=0;i<items.length;i++)
    	{
    		alert (items.item(i).firstChild.data);
    	}
    }
    	</script>
    </head>
    <body>
    <p>Pseudo</p><br />
    <input name="pseudo" id="id_pseudo" type="text" /><br /><br />
    <p>Message</p><br />
    <textarea rows="5" cols="70" name="message" id="id_message" type="text"></textarea><br /><br />
    <input type="button" value="Poster" onClick="checkPostLivreDor()" />
    </form>
     
    </body>
    </html>
    Pour ton php
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    <?php
    header('Content-Type: text/xml'); 
    echo "<?xml version=\"1.0\"?>\n";
    echo "<exemple>\n";
            echo "<donnee>Test !</donnee>\n";
    echo "</exemple>\n";
     
    ?>

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    266
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 266
    Par défaut
    En effet c'est le <form> qui posait problème.
    En le supprimant, cela marche.

    Merci.

  5. #5
    Membre éprouvé
    Profil pro
    Développeur Web
    Inscrit en
    Juillet 2007
    Messages
    112
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2007
    Messages : 112
    Par défaut
    Mais derien

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

Discussions similaires

  1. [AJAX] Ajax, formulaire, div et select
    Par n8ken dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 23/09/2006, 10h51
  2. formulaire (post - get)
    Par Yoshio dans le forum Langage
    Réponses: 5
    Dernier message: 22/01/2006, 16h30
  3. [AJAX] Formulaire prépopuler avec du ajax dans la page
    Par shwin dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 31/10/2005, 15h37
  4. Pb de formulaire Post avec javascript
    Par critok dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 28/09/2005, 15h31
  5. Formulaire posté sur la mauvaise page
    Par Prue dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 15/07/2005, 12h27

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