Bonjour à tous et bonne année,

Je suis débutant en Ajax je commence à peine à me pencher dessus mais je rencontre déjà un soucis.

J'ai fais un formulaire simple :
Code html : 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
<form class=cf>
 
<label>Qui êtes vous envers Paul ?</label></br>
 
<select name=qui_com id="soflow" required >
 
 <option value="sup">Un supérieur</option>
 <option value="col">Un collègue</option>
 <option value="ami">Un amis</option>
 <option value="inc">Un inconnu</option>
 <option value="fam">Un membre de la famille</option>
 
</select></br>
 
<input class=focus type=text name=nom_com placeholder=Nom required></br>
 
<input class=focus type=text name=prenom_com placeholder=Prenom required></br>
 
<textarea name=message_com type=text id=input-message placeholder=Message required></textarea></br>
 
<main class=container>
 
<button class="myButt one" type=button onclick="request(commentaire_form);" class=customButton>
 
<div class=insider></div>
VALIDER
 
</button>
 
</main>
 
</form>

En gros en Ajax je veux faire en sorte que quand je clique sur envoyer ca analyse les valeurs des champs du formulaire et si y en a une de vide bah ça fasse une alert "ca marche pas" et si tout les champs sont remplie bah que ça fasse alert "Ca marche".

Du coup j'ai fais ça :
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
function getXMLHttpRequest() {
    var xhr = null;
 
    if (window.XMLHttpRequest || window.ActiveXObject) {
        if (window.ActiveXObject) {
            try {
                xhr = new ActiveXObject("Msxml2.XMLHTTP");
            } catch(e) {
                xhr = new ActiveXObject("Microsoft.XMLHTTP");
            }
        } else {
            xhr = new XMLHttpRequest();
        }
    } else {
        alert("Votre navigateur ne supporte pas l'objet XMLHTTPRequest...");
        return null;
    }
 
    return xhr;
}
 
function request(callback) {
 
    var xhr = getXMLHttpRequest();
 
    xhr.onreadystatechange = function() {
        if (xhr.readyState == 4 && (xhr.status == 200 || xhr.status == 0)) {
            callback(xhr.responseText);
        }
    };
 
    var qui = encodeURIComponent(document.getElementsByName("qui_com").value);
    var nom = encodeURIComponent(document.getElementsByName("nom_com").value);
    var prenom = encodeURIComponent(document.getElementsByName("prenom_com").value);
    var message = encodeURIComponent(document.getElementsByName("message_com").value);
 
    xhr.open("POST", "test_com.php", true);
    xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    xhr.send('Qui=' + qui + '&Nom=' + nom + '&Prenom=' + prenom + '&Message=' + message);
 
}
 
function commentaire_form(data) {
    alert(data);
}
et enfin la page php qui doit analyser les variables pour renvoyer le bon texte en fonction :
Code php : 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
<?php
 
header("Content-Type: text/plain");
 
if ((isset($_POST["Qui"]) AND !empty($_POST["Qui"])) AND (isset($_POST["Nom"]) AND !empty($_POST["Nom"])) AND (isset($_POST["Prenom"]) AND !empty($_POST["Prenom"])) AND (isset($_POST["Message"]) AND !empty($_POST["Message"]))) {
 
    echo "CA MARCHE";
 
}
else {
 
    echo "CA MARCHE PAS";
 
}
 
?>