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 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
| <!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="UTF-8">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script>
$(function() {
$("#myform").find("input[type=submit]").on('click',function(event){
event.stopPropagation(); // stop la propagation du click
event.preventDefault(); // annule le comportement par défaut (ici = soumission du formulaire)
var formulaire = $(this).parents('form:first'); // $(this).parents('form:first') représente le formulaire. J'utilise la syntaxe "parents('form:first')" pour que le code reste fonctionnel si l'input de type submit n'avait pas le formulaire comme parent direct, par exemple s'il était inclus dans un div.
var content_erreurs = $("#erreurs"); // bloc html contenant les erreurs
content_erreurs.html(''); // efface le contenu
var erreurs = []; //initialise un tableau javascript
function controleForm(form)
{
var input1 = form.find("input[name=name_1]");
// $.trim est utilisé pour éviter qu'un champ rempli uniquement par des espaces vides soit considéré comme valide
if($.trim(input1.val()) == '')
{
// récupère le text du label et l'ajoute dans le tableau "erreurs"
erreurs.push(input1.parent('label').text());
}
var input2 = form.find("input[name=name_2]");
if($.trim(input2.val()) == '')
{
erreurs.push(input2.parent('label').text());
}
}
// Appelle la fonction de contrôle
controleForm(formulaire);
if(erreurs.length > 0)
{
// content_erreurs.data("erreur") récupère l'annonce des erreurs contenu dans l'attribut "data-erreur" du div ayant l'id="erreurs"
var message_erreur = '<p>'+content_erreurs.data("erreur")+'</p>';
// Liste le tableau des erreurs
$.each(erreurs,function(i,v)
{
message_erreur += '<p>- '+v+'</p>';
})
content_erreurs.html($(message_erreur)); // rempli le div conteneur des erreurs
}
else
{
formulaire.submit();// soumet le formulaire
}
});
});
</script>
</head>
<body>
<form id="myform" action="#" method="post">
<label>champ name1<input type="text" name="name_1"></label><br>
<label>champ name2<input type="text" name="name_2"></label><br>
<input type="submit" value = "Soumettre">
</form>
<div id="erreurs" style="color:red" data-erreur='Les champs suivants doivent être renseignés:'></div>
</body>
</html> |
Partager