--- title: ':optional' slug: 'Web/CSS/:optional' tags: - CSS - Pseudo-classe - Reference translation_of: 'Web/CSS/:optional' --- <div>{{CSSRef}}</div> <p>La <a href="/fr/docs/Web/CSS/Pseudo-classes">pseudo-classe</a> <strong><code>:optional</code></strong> permet de cibler les éléments {{HTMLElement("input")}} ou {{HTMLElement("textarea")}} pour lesquels l'attribut {{htmlattrxref("required","input")}} n'est pas activé. Cela permet ainsi d'indiquer et de mettre en forme les champs facultatifs d'un formulaire.</p> <pre class="brush: css no-line-numbers">/* Cible les élméents <input> qui sont optionnels */ /* c'est-à-dire qui n'ont pas d'attribut required */ input:optional { border: 1px dashed black; }</pre> <div class="note"> <p><strong>Note :</strong> Afin de mettre en forme les champs obligatoires, on pourra utiliser la pseudo-classe {{cssxref(":required")}}.</p> </div> <h2 id="Syntaxe">Syntaxe</h2> <pre class="syntaxbox">{{csssyntax}}</pre> <h2 id="Exemples">Exemples</h2> <h3 id="CSS">CSS</h3> <pre class="brush: css">input { border-width: 3px; } input:optional { border-color: #008000; } input:required { border-color: #800000; }</pre> <h3 id="HTML">HTML</h3> <pre class="brush: html"><form> <label for="url-input">Tapez une URL :</label> <input type="url" id="url-input"> <br> <br> <label for="email-input">Tapez une adresse électronique :</label> <input type="email" id="email-input" required> </form> </pre> <h3 id="Résultat">Résultat</h3> <p>{{EmbedLiveSample('Exemples','100%',150)}}</p> <h2 id="Accessibilité">Accessibilité</h2> <p>Si un formulaire ({{HTMLElement("form")}}) contient des champs ({{htmlelement("input")}}) optionnels, les champs obligatoires doivent être indiqués avec l'attribut {{htmlattrxref("input","required")}}. 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.</p> <p>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é.</p> <ul> <li><a href="/fr/docs/Web/Accessibility/Understanding_WCAG/Perceivable#Guideline_1.4_Make_it_easier_for_users_to_see_and_hear_content_including_separating_foreground_from_background">Explications des recommendation WCAG 1.4</a></li> <li><a href="https://www.w3.org/TR/UNDERSTANDING-WCAG20/visual-audio-contrast-contrast.html" rel="noopener">Understanding Success Criterion 1.4.3 | W3C Understanding WCAG 2.0</a></li> </ul> <h2 id="Spécifications">Spécifications</h2> <table class="standard-table"> <thead> <tr> <th scope="col">Spécification</th> <th scope="col">État</th> <th scope="col">Commentaires</th> </tr> </thead> <tbody> <tr> <td>{{SpecName('HTML WHATWG', '#selector-optional', ':optional')}}</td> <td>{{Spec2('HTML WHATWG')}}</td> <td>Aucune modification.</td> </tr> <tr> <td>{{SpecName('HTML5 W3C', '#selector-optional', ':optional')}}</td> <td>{{Spec2('HTML5 W3C')}}</td> <td>Définition de la sémantique relative à HTML et aux contraintes de validation.</td> </tr> <tr> <td>{{SpecName('CSS4 Selectors', '#opt-pseudos', ':optional')}}</td> <td>{{Spec2('CSS4 Selectors')}}</td> <td>Aucune modification.</td> </tr> <tr> <td>{{SpecName('CSS3 Basic UI', '#pseudo-required-value', ':optional')}}</td> <td>{{Spec2('CSS3 Basic UI')}}</td> <td>Définition de la pseudo-classe mais sans la sémantique associée.</td> </tr> </tbody> </table> <h2 id="Compatibilité_des_navigateurs">Compatibilité des navigateurs</h2> <div class="hidden">Ce tableau de compatibilité a été généré à partir de données structurées. Si vous souhaitez contribuer à ces données, n'hésitez pas à envoyer une <em>pull request</em> sur <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a>.</div> <p>{{Compat("css.selectors.optional")}}</p> <h2 id="Voir_aussi">Voir aussi</h2> <ul> <li>{{cssxref(":required")}}</li> <li>{{cssxref(":invalid")}}</li> <li>{{cssxref(":valid")}}</li> <li><a href="/fr/docs/Web/Guide/HTML/Formulaires/Validation_donnees_formulaire">La validation des données de formulaire</a></li> </ul>