1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
---
title: ':optional'
slug: 'Web/CSS/:optional'
tags:
- CSS
- Diseño
- Pseudo-clase
- Referencia
- Web
translation_of: 'Web/CSS/:optional'
---
<div>{{ CSSRef }}</div>
<p>La <a href="/es/docs/Web/CSS/Pseudo-classes">pseudo-clase</a> <strong><code>:optional</code></strong> de <a href="/es/docs/Web/CSS">CSS</a> representa cualquier elemento {{HTMLElement("input")}}, {{HTMLElement("select")}}, o {{HTMLElement("textarea")}} que no tenga el atributo {{ htmlattrxref("required", "input") }} establecido en él.</p>
<pre class="brush: css no-line-numbers">/* Selecciona cualquier opción <input> */
input:optional {
border: 1px dashed black;
}</pre>
<p>Esta pseudo-clase es útil para diseñar campos que no son necesarios para enviar un formulario.</p>
<div class="note">
<p><strong>Nota:</strong> La pseudo-clase {{cssxref(":required")}} selecciona los campos de formulario <em>requeridos</em>.</p>
</div>
<h2 id="Sintaxis">Sintaxis</h2>
{{csssyntax}}
<h2 id="Ejemplos">Ejemplos</h2>
<p>Ver {{cssxref(":invalid")}} para un ejemplo.</p>
<h2 id="Problemas_de_accesibilidad">Problemas de accesibilidad</h2>
<p>Si un <a href="/es/docs/Web/HTML/Element/form">formulario</a> contiene {{htmlelement("input")}}s opcionales, las entradas requeridas deben indicarse utilizando el atributo {{ htmlattrxref("required", "input") }}. Esto se asegurará de que las personas que navegan con la ayuda de la tecnología de asistencia, como un lector de pantalla, puedan comprender qué entradas necesitan contenido válido para garantizar el envío exitoso del formulario.</p>
<p>Las entradas requeridas también deben indicarse visualmente, utilizando un tratamiento que no dependa únicamente del color para transmitir el significado. Por lo general, se utilizan textos descriptivos y/o un icono.</p>
<ul>
<li><a href="/en-US/docs/Web/Accessibility/Understanding_WCAG/Understandable#Guideline_3.3_%E2%80%94_Input_Assistance_Help_users_avoid_and_correct_mistakes">MDN Understanding WCAG, Guideline 3.3 explanations</a></li>
<li><a href="https://www.w3.org/TR/UNDERSTANDING-WCAG20/minimize-error-cues.html">Understanding Success Criterion 3.3.2 | W3C Understanding WCAG 2.0</a></li>
</ul>
<h2 id="Especificaciones">Especificaciones</h2>
<table class="standard-table">
<thead>
<tr>
<th scope="col">Especificación</th>
<th scope="col">Estado</th>
<th scope="col">Comentario</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{ SpecName('HTML WHATWG', '#selector-optional', ':optional') }}</td>
<td>{{ Spec2('HTML WHATWG') }}</td>
<td>Ningún cambio.</td>
</tr>
<tr>
<td>{{ SpecName('HTML5 W3C', '#selector-optional', ':optional') }}</td>
<td>{{ Spec2('HTML5 W3C') }}</td>
<td>Define la semántica de HTML y la validación de restricciones.</td>
</tr>
<tr>
<td>{{ SpecName('CSS4 Selectors', '#opt-pseudos', ':optional') }}</td>
<td>{{ Spec2('CSS4 Selectors') }}</td>
<td>Ningún cambio.</td>
</tr>
<tr>
<td>{{ SpecName('CSS3 Basic UI', '#pseudo-required-value', ':optional') }}</td>
<td>{{ Spec2('CSS3 Basic UI') }}</td>
<td>Define la pseudoclase, pero no la semántica asociada.</td>
</tr>
</tbody>
</table>
<h2 id="Compatibilidad_con_navegadores">Compatibilidad con navegadores</h2>
<p>{{Compat("css.selectors.optional")}}</p>
<h2 id="Ver_también">Ver también</h2>
<ul>
<li>Otras pseudo-clases relacionadas con la validación: {{ cssxref(":required") }}, {{ cssxref(":invalid") }}, {{ cssxref(":valid") }}</li>
<li><a href="/en-US/docs/Learn/HTML/Forms/Form_validation">Validación de datos de formulario</a></li>
</ul>
|