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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
|
---
title: Uso de propiedades personalizadas (variables) en CSS
slug: Web/CSS/Using_CSS_custom_properties
tags:
- CSS
- Guía
- Propiedades personalizadas CSS
- Varables CSS
- Web
translation_of: Web/CSS/Using_CSS_custom_properties
---
<div>{{cssref}}</div>
<p>En CSS, las <strong>propiedades personalizadas</strong> (también conocidas como<strong> variables</strong>) son entidades definidas por autores de CSS que contienen valores específicos que se pueden volver a utilizar en un documento. Se establecen mediante la notación de propiedades personalizadas (por ejemplo,<strong> </strong><strong><code>--main-color: black;</code></strong>) y se acceden mediante la función {{cssxref("var", "var()")}} (por ejemplo, color: <strong><code>var (--main-color);</code></strong>).</p>
<p>Sitios web complejos tienen cantidades muy grandes de CSS, a menudo con una gran cantidad de valores repetidos. Por ejemplo, el mismo color se puede utilizar en cientos de lugares diferentes, lo cual requiere buscar y reemplazar globalmente si necesitamos cambiar ese color. Las variables CSS permiten que un valor se almacene en un lugar y luego se haga referencia en varios otros lugares. Un beneficio adicional son los identificadores semánticos. Por ejemplo <strong><code>--main-text-color</code></strong> es más fácil de entender que <strong><code>#00ff00</code></strong>, especialmente si este mismo color también se utiliza en otro contexto.</p>
<p>Las variables CSS están sujetas a la cascada, y heredan su valor de su padre.</p>
<h2 id="Uso_Básico">Uso Básico</h2>
<p>Para declarar propiedades personalizadas (variables) usamos un nombre que comienze con dos guiones (<code>--</code>), y un valor que puede ser cualquier valor válido de CSS. Como cualquier otra propiedad, la escribimos dentro de un set de reglas de estilo, algo así:</p>
<pre class="brush:css; highlight:[2] language-css notranslate">elemento {
--main-bg-color: brown;
}
</pre>
<p>Ten en cuenta que el selector que usemos para las reglas de estilo define el ámbito (scope) en el que podremos usar la propiedad personalizada (variable). Una buena práctica común es declarar variables en la pseudo-clase {{cssxref(":root")}}, y así aplicarlas globalmente al documento HTML:</p>
<pre class="brush: css notranslate">:root {
--main-bg-color: brown;
}</pre>
<p>Sin embargo, esto no tiene por qué ser siempre así: podrían haber muy buenas razones para querer limitar el ámbito de tus propiedades personalizadas.</p>
<div class="blockIndicator note">
<p><strong>Nota</strong>: Los nombres de propiedades personalizadas son case sensitive (distinguen entre mayúsuculas y minúsculas) — <code>--my-color</code> será tratado como una propiedad personalizada distinta a <code>--My-color</code>.</p>
</div>
<p>Como mencionamos anteriormente, para acceder al valor de una propiedad personalizada usamos el nombre de la propiedad dentro de la función {{cssxref("var()")}}, en lugar de cualquier otro valor normal:</p>
<pre class="brush:css; highlight:[2] language-css notranslate">elemento {
background-color: var(--main-bg-color);
}
</pre>
<h2 id="Primeros_pasos_con_propiedades_personalizadas_variables">Primeros pasos con propiedades personalizadas (variables)</h2>
<p>Comencemos con este simple CSS que colorea elementos de diferentes clases con el mismo color:</p>
<div id="sample1">
<pre class="brush:css; highlight:[3,20,26,32] notranslate">.uno {
color: white;
background-color: brown;
margin: 10px;
width: 50px;
height: 50px;
display: inline-block;
}
.dos {
color: white;
background-color: black;
margin: 10px;
width: 150px;
height: 70px;
display: inline-block;
}
.tres {
color: white;
background-color: brown;
margin: 10px;
width: 75px;
}
.cuatro {
color: white;
background-color: brown;
margin: 10px;
width: 100px;
}
.cinco {
background-color: brown;
}
</pre>
<p>Lo aplicaremos a este HTML:</p>
<pre class="brush:html notranslate"><div>
<div class="uno">1:</div>
<div class="dos">2: Texto <span class="cinco">5 - más texto</span></div>
<input class="tres">
<textarea class="cuatro">4: Lorem Ipsum</textarea>
</div>
</pre>
<p>... lo cual nos lleva a esto:</p>
<p>{{EmbedLiveSample("sample1",600,180)}}</p>
<p>Observa la repetición en el CSS. El color de fondo se pone a marrón (<code>brown</code>) en varios lugares. Para algunas declaraciones CSS, es posible declarar esto más alto en la cascada y dejar que la herencia CSS resuelva este problema de forma natural. Para proyectos no triviales, esto no siempre es posible. Al declarar una variable en la pseudo-clase {{cssxref(":root")}}, podemos evitar repetición usando la variable.</p>
</div>
<div id="sample2">
<pre class="brush: css notranslate">:root {
--main-bg-color: brown;
}
.uno {
color: white;
background-color: var(--main-bg-color);
margin: 10px;
width: 50px;
height: 50px;
display: inline-block;
}
.dos {
color: white;
background-color: black;
margin: 10px;
width: 150px;
height: 70px;
display: inline-block;
}
.tres {
color: white;
background-color: var(--main-bg-color);
margin: 10px;
width: 75px;
}
.cuatro {
color: white;
background-color: var(--main-bg-color);
margin: 10px;
width: 100px;
}
.cinco {
background-color: var(--main-bg-color);
}
</pre>
</div>
<p>Esto conduce al mismo resultado que el ejemplo anterior pero permite una declaración canónica de la propiedad deseada; muy útil si queremos cambiar el valor en toda la página más tarde.</p>
<h2 id="Herencia_de_propiedades_personalizadas">Herencia de propiedades personalizadas</h2>
<p>Las propiedades personalizadas heredan. Lo que significa que si no se establece ningún valor para una propiedad personalizada en un elemento dado, se utiliza el valor de su elemento padre. Veámos el siguiente HTML:</p>
<pre class="brush: html notranslate"><div class="uno">
<div class="dos">
<div class="tres"></div>
<div class="cuatro"></div>
</div>
</div></pre>
<p>... con el siguiente CSS:</p>
<pre class="brush: css notranslate">.dos {
--test: 10px;
}
.tres {
--test: 2em;
}
</pre>
<p>En este caso, los resultados de <code>var(--test)</code> son:</p>
<ul>
<li>Para el elemento <code>class="dos"</code>: <code>10px</code></li>
<li>Para el elemento <code>class="tres"</code>: <code>2em</code></li>
<li>Para el elemento <code>class="cuatro"</code>: <code>10px</code> (heredado de su padre)</li>
<li>Para el elemento <code>class="uno"</code>: <em>valor no válido</em>, que es el valor predeterminado de cualquier propiedad personalizada.</li>
</ul>
<p>Tenga en cuenta que éstas son propiedades personalizadas, no variables reales como podemos encontrar en otros lenguajes de programación. El valor se calcula donde sea necesario, no se almacena para su uso en otras reglas. Por ejemplo, no se puede declarar una propiedad para un elemento y esperar recuperarla en las reglas del descendiente de un hermano. La propiedad sólo está configurada para el selector que coincida y sus descendientes, como cualquier CSS normal.</p>
<h2 id="Valores_de_sustitución_fallback_de_propiedades_personalizadas">Valores de sustitución (fallback) de propiedades personalizadas</h2>
<p>Utilizando <code><a href="/es/docs/Web/CSS/var">var()</a></code> podemos definir múltiples <strong> valores de sustitución (fallback)</strong> que se usarán cuando la variable dada no está definida aún; esto puede ser útil cuando se trabaja con <a href="/es/docs/Web/Web_Components/Using_custom_elements">Custom Elements</a> y <a href="/es/docs/Web/Web_Components/Using_shadow_DOM">Shadow DOM</a>.</p>
<div class="note">
<p><strong>Los valores de sustitución (fallback) no se usan para arreglar problemas de compatibilidad del navegador.</strong> Si el navegador no tiene soporte para Propiedades Personalizadas de CSS, el valor de fallback no es de ayuda. <strong>Es simplemente un respaldo para que aquellos navegadores que sí soportan Propiedades Personalizadas de CSS</strong> puedan elegir un valor diferente en caso de que la variable no se haya definido o contenga un valor no válido.</p>
</div>
<p>El primer argumento a la función es el nombre de la <a href="https://www.w3.org/TR/css-variables/#custom-property"> propiedad personalizada </a> que se va a sustituir. El segundo argumento a la función, si se proporciona, es un valor de reserva, que se utiliza como valor de sustitución cuando la <a href="https://www.w3.org/TR/css-variables/#custom-property"> propiedad personalizada </a> referenciada no es válida. La función solo acepta dos parámetros, asignando todo lo que después de la primera coma como el segundo parámetro. Si ese segundo parámetro es inválido, por ejemplo una lista de valores separados por comas, el fallback fallará. Por ejemplo:</p>
<pre class="brush: css notranslate">.dos {
color: var(--my-var, red); /* Rojo (red) si --my-var no esta definida */
}
.tres {
background-color: var(--my-var, var(--my-background, pink)); /* Rosa (pink) si my-var y --my-background no están definidas */
}
.tres {
background-color: var(--my-var, --my-background, pink); /* Invalido: "--background, pink" */
}</pre>
<p>Como vemos en el segundo ejemplo de arriba, la manera correcta de incluir más de un fallback es usar una propiedad personalizada como fallback (la cual tiene su propio fallback). Esta técnica se ha visto que puede causar problemas de rendimiento al tomar más tiempo analizar las variables.</p>
<div class="note">
<p><strong>Nota:</strong> La sintaxis del fallback, como la de las <a href="https://www.w3.org/TR/css-variables/#custom-property">propiedades personalizadas</a>, permite comas. Por ejemplo, <code>var(--foo, red, blue)</code> define un fallback de <code>red, blue</code> — es decir, cualquier cosa entre la primera coma y el final de la función se considera un valor de fallback.</p>
</div>
<h2 id="Validez_y_valores">Validez y valores</h2>
<p>El clásico concepto de validez en CSS, vinculado a cada propiedad, no es muy útil con respecto a las propiedades personalizadas. Cuando se analizan los valores de las propiedades personalizadas, el navegador no sabe dónde se utilizarán, por lo que debe considerar casi todos los valores como <em>válidos</em>.</p>
<p>Desafortunadamente, estos valores válidos se pueden usar, a través de la notación funcional <code>var()</code>, en un contexto en el que tal vez no tengan sentido. Propiedades y variables personalizadas pueden llevar a declaraciones CSS no válidas, dando lugar al nuevo concepto de <em>válido en tiempo calculado.</em></p>
<h2 id="¿Qué_pasa_con_los_valores_inválidos">¿Qué pasa con los valores inválidos?</h2>
<p>Cuando el navegador encuentra una sustitución inválida con <code>var()</code>, se usará el valor inicial o heredado.</p>
<p>Considera el siguiente fragmento:</p>
<h3 id="HTML">HTML</h3>
<pre class="brush: html notranslate"><p>This paragraph is initial black.</p> </pre>
<h3 id="CSS">CSS</h3>
<pre class="brush: css notranslate">:root { --text-color: 16px; }
p { color: blue; }
p { color: var(--text-color); }</pre>
<p>Como esperaríamos, el navegador sustituye <code>var(--text-color)</code> con el valor de <code>--text-color</code>, pero <code>16px</code> no es un valor válido para la propiedad {{cssxref("color")}}. Después de la sustitución, la propiedad no tiene sentido. El navegador maneja esta situación en dos pasos:</p>
<ol>
<li>Comprueba si la propiedad color se puede heredar. Sí, pero el elemento <code><p></code> no tiene un padre con una propiedad color. Así que pasamos al siguiente paso.</li>
<li>Toma el valor de su <strong>valor inicial por defecto</strong>.</li>
</ol>
<h3 id="Resultado">Resultado</h3>
<p>{{EmbedLiveSample('What_happens_with_invalid_variables')}}</p>
<p>El color del párrafo no será azul (blue) porque la sustición inválida se reemplaza con el valor inicial, no el fallback. Si hubiéramos escrito <code>color: 16px</code> sin ninguna sustitución de variables, sería entonces un error de sintaxis. La declaración anterior será usada.</p>
<h2 id="Valores_en_JavaScript">Valores en JavaScript</h2>
<p>Para utilizar los valores de las propiedades personalizadas en JavaScript, es como las propiedades estándar.</p>
<pre class="brush: js notranslate">// Obtener la variable desde el estilo inline
element.style.getPropertyValue("--my-var");
// Obtener variable desde cualquier lugar
getComputedStyle(element).getPropertyValue("--my-var");
// Establecer variable en estilo inline
element.style.setProperty("--my-var", jsVar + 4);
</pre>
<h2 id="Compatibilidad_en_navegadores">Compatibilidad en navegadores</h2>
<p>{{Compat("css.properties.custom-property")}}</p>
<h2 id="Ver_también">Ver también</h2>
<ul>
<li><a href="/en-US/docs/Web/CSS/--*" title="The documentation about this has not yet been written; please consider contributing!"><code>custom properties</code></a></li>
</ul>
|