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 -