:optional
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 :optional
permet de cibler les éléments <input>
ou <textarea>
pour lesquels l'attribut required
n'est pas activé. Cela permet ainsi d'indiquer et de mettre en forme les champs facultatifs d'un formulaire.
Exemple interactif
label {
display: block;
margin-top: 1em;
}
.req {
color: red;
}
*:optional {
background-color: palegreen;
}
<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 requis</p>
</form>
La pseudo-classe :optional
est utile pour mettre en forme les champs qui ne sont pas obligatoires pour soumettre un formulaire.
Note :
La pseudo-classe :required
sélectionne les champs de formulaire obligatoires.
Syntaxe
:optional {
/* ... */
}
Accessibilité
Si un formulaire 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
>L'élément optionnel a une bordure violette
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:optional {
border-color: rebeccapurple;
border-width: 3px;
}
Résultat
Spécifications
Specification |
---|
HTML> # selector-optional> |
Selectors Level 4> # optional-pseudo> |
Compatibilité des navigateurs
Chargement…
Voir aussi
- Les autres pseudo-classes liées à la validation :
- La validation des données de formulaire