Cette page a été traduite à partir de l'anglais par la communauté. Vous pouvez contribuer en rejoignant la communauté francophone sur MDN Web Docs.
:required
Baseline
Widely available
Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis juillet 2015.
La pseudo-classe CSS :required permet de cibler un élément <input> pour lequel l'attribut required est activé. Cela permet de mettre en forme les éléments obligatoires pour remplir correctement un formulaire.
Exemple interactif
label {
display: block;
margin-top: 1em;
}
.req {
color: red;
}
*:required {
background-color: gold;
}
<form>
<label for="name">Nom : <span class="req">*</span></label>
<input id="name" name="name" type="text" required />
<label for="birth">Date de naissance :</label>
<input id="birth" name="birth" type="date" />
<label for="origin"
>Comment avez-vous entendu parler de nous ?
<span class="req">*</span></label
>
<select id="origin" name="origin" required>
<option>Google</option>
<option>Facebook</option>
<option>Publicité</option>
</select>
<p><span class="req">*</span> - Champ obligatoire</p>
</form>
La pseudo-classe est utile pour mettre en évidence les champs qui doivent contenir des données valides avant qu'un formulaire puisse être soumis.
Note :
La pseudo-classe :optional pourra être utilisée pour mettre en forme les champs facultatifs.
Syntaxe
:required {
/* ... */
}
Accessibilité
Si un formulaire (<form>) contient des champs (<input>) optionnels, les champs obligatoires doivent être indiqués avec l'attribut input. Ainsi, les personnes utilisant des outils d'assistance (par exemple un lecteur d'écran) pourront savoir que ces champs ont besoin d'un contenu valide afin de pouvoir envoyer le formulaire.
Les champs obligatoires devraient également être indiqués visuellement et cette indication ne doit pas uniquement être fournie avec une couleur. Généralement, un texte descriptif ou une icône est utilisé.
Exemples
>Le champ requis a une bordure rouge
HTML
<form>
<div class="field">
<label for="url_input">Tapez une URL :</label>
<input type="url" id="url-input" />
</div>
<div class="field">
<label for="email_input">Tapez une adresse électronique :</label>
<input type="email" id="email-input" required />
</div>
</form>
CSS
label {
display: block;
margin: 1px;
padding: 1px;
}
.field {
margin: 1px;
padding: 1px;
}
input:required {
border-color: maroon;
border-width: 3px;
}
input:required:invalid {
border-color: #c00000;
}
Résultat
Spécifications
| Specification |
|---|
| HTML> # selector-required> |
| Selectors Level 4> # required-pseudo> |
Compatibilité des navigateurs
Chargement...
Voir aussi
- Les autres pseudo-classes liées à la validation :
- La validation des données d'un formulaire