HTML5 - Formulaires Web 2.0
Web Forms 2.0 est une extension des fonctionnalités de formulaires présentes dans HTML4. Les éléments de formulaire et les attributs en HTML5 fournissent un plus grand degré de balisage sémantique que HTML4 et nous libèrent de beaucoup de scripts et de styles fastidieux qui étaient requis dans HTML4.
L'élément <input> en HTML4
Les éléments d'entrée HTML4 utilisent le type attribut pour spécifier le type de données.HTML4 fournit les types suivants -
N ° Sr. | Type et description |
---|---|
1 | text Un champ de texte de forme libre, nominalement exempt de sauts de ligne. |
2 | password Un champ de texte de forme libre pour les informations sensibles, nominalement exempt de sauts de ligne. |
3 | checkbox Un ensemble de zéro ou plusieurs valeurs à partir d'une liste prédéfinie. |
4 | radio Une valeur énumérée. |
5 | submit Un formulaire gratuit de bouton lance la soumission du formulaire. |
6 | file Un fichier arbitraire avec un type MIME et éventuellement un nom de fichier. |
sept | image Une coordonnée, relative à la taille d'une image particulière, avec la sémantique supplémentaire qu'elle doit être la dernière valeur sélectionnée et lance la soumission du formulaire. |
8 | hidden Une chaîne arbitraire qui n'est normalement pas affichée à l'utilisateur. |
9 | select Une valeur énumérée, un peu comme le type de radio. |
dix | textarea Un champ de texte de forme libre, nominalement sans restrictions de saut de ligne. |
11 | button Une forme libre de bouton qui peut déclencher tout événement lié au bouton. |
Voici un exemple simple d'utilisation d'étiquettes, de boutons radio et de boutons d'envoi -
...
<form action = "http://example.com/cgiscript.pl" method = "post">
<p>
<label for = "firstname">first name: </label>
<input type = "text" id = "firstname"><br />
<label for = "lastname">last name: </label>
<input type = "text" id = "lastname"><br />
<label for = "email">email: </label>
<input type = "text" id = "email"><br>
<input type = "radio" name = "sex" value = "male"> Male<br>
<input type = "radio" name = "sex" value = "female"> Female<br>
<input type = "submit" value = "send"> <input type = "reset">
</p>
</form>
...
L'élément <input> en HTML5
Outre les attributs mentionnés ci-dessus, les éléments d'entrée HTML5 ont introduit plusieurs nouvelles valeurs pour le typeattribut. Ceux-ci sont énumérés ci-dessous.
NOTE - Essayez tous les exemples suivants en utilisant la dernière version de Opera navigateur.
N ° Sr. | Type et description |
---|---|
1 | datetime
Une date et une heure (année, mois, jour, heure, minute, seconde, fractions de seconde) codées selon ISO 8601 avec le fuseau horaire défini sur UTC. |
2 | datetime-local
Une date et une heure (année, mois, jour, heure, minute, seconde, fractions de seconde) encodées selon ISO 8601, sans informations de fuseau horaire. |
3 | Date
Une date (année, mois, jour) encodée selon ISO 8601. |
4 | mois
Une date composée d'une année et d'un mois codée selon ISO 8601. |
5 | la semaine
Une date composée d'une année et d'un numéro de semaine codés selon ISO 8601. |
6 | temps
Une heure (heure, minute, seconde, fraction de seconde) codée selon ISO 8601. |
sept | nombre
Il n'accepte que la valeur numérique. L'attribut step spécifie la précision, par défaut à 1. |
8 | intervalle
Le type de plage est utilisé pour les champs d'entrée qui doivent contenir une valeur d'une plage de nombres. |
9 | email
Il n'accepte que la valeur e-mail. Ce type est utilisé pour les champs de saisie qui doivent contenir une adresse e-mail. Si vous essayez d'envoyer un texte simple, cela oblige à saisir uniquement l'adresse e-mail au format [email protected]. |
dix | URL
Il n'accepte que la valeur URL. Ce type est utilisé pour les champs de saisie qui doivent contenir une adresse URL. Si vous essayez d'envoyer un texte simple, cela oblige à entrer uniquement l'adresse URL soit au format http://www.example.com soit au format http://example.com. |
L'élément <output>
HTML5 a introduit un nouvel élément <output> qui est utilisé pour représenter le résultat de différents types de sortie, comme la sortie écrite par un script.
Vous pouvez utiliser le forattribut pour spécifier une relation entre l'élément de sortie et d'autres éléments du document qui ont affecté le calcul (par exemple, en tant qu'entrées ou paramètres). La valeur de l'attribut for est une liste d'ID d'autres éléments séparés par des espaces.
<!DOCTYPE HTML>
<html>
<head>
<script type = "text/javascript">
function showResult() {
x = document.forms["myform"]["newinput"].value;
document.forms["myform"]["result"].value = x;
}
</script>
</head>
<body>
<form action = "/cgi-bin/html5.cgi" method = "get" name = "myform">
Enter a value : <input type = "text" name = "newinput" />
<input type = "button" value = "Result" onclick = "showResult();" />
<output name = "result"></output>
</form>
</body>
</html>
Il produira le résultat suivant -
L'attribut d'espace réservé
HTML5 a introduit un nouvel attribut appelé placeholder. Cet attribut sur les éléments <input> et <textarea> fournit une indication à l'utilisateur de ce qui peut être saisi dans le champ. Le texte de l'espace réservé ne doit pas contenir de retours chariot ni de sauts de ligne.
Voici la syntaxe simple pour l'attribut d'espace réservé -
<input type = "text" name = "search" placeholder = "search the web"/>
Cet attribut est uniquement pris en charge par les dernières versions des navigateurs Mozilla, Safari et Crome.
<!DOCTYPE HTML>
<html>
<body>
<form action = "/cgi-bin/html5.cgi" method = "get">
Enter email : <input type = "email" name = "newinput"
placeholder = "[email protected]"/>
<input type = "submit" value = "submit" />
</form>
</body>
</html>
Cela produira le résultat suivant -
L'attribut autofocus
Il s'agit d'un modèle simple en une étape, facilement programmé en JavaScript au moment du chargement du document, qui concentre automatiquement un champ de formulaire particulier.
HTML5 a introduit un nouvel attribut appelé autofocus qui serait utilisé comme suit -
<input type = "text" name = "search" autofocus/>
Cet attribut est uniquement pris en charge par les dernières versions des navigateurs Mozilla, Safari et Chrome.
<!DOCTYPE HTML>
<html>
<body>
<form action = "/cgi-bin/html5.cgi" method = "get">
Enter email : <input type = "text" name = "newinput" autofocus/>
<p>Try to submit using Submit button</p>
<input type = "submit" value = "submit" />
</form>
</body>
</html>
L'attribut requis
Désormais, vous n'avez pas besoin d'avoir JavaScript pour les validations côté client, car une zone de texte vide ne serait jamais soumise car HTML5 a introduit un nouvel attribut appelé required qui serait utilisé comme suit et insisterait pour avoir une valeur -
<input type = "text" name = "search" required/>
Cet attribut est uniquement pris en charge par les dernières versions des navigateurs Mozilla, Safari et Chrome.
<!DOCTYPE HTML>
<html>
<body>
<form action = "/cgi-bin/html5.cgi" method = "get">
Enter email : <input type = "text" name = "newinput" required/>
<p>Try to submit using Submit button</p>
<input type = "submit" value = "submit" />
</form>
</body>
</html>
Il produira le résultat suivant -