aboutsummaryrefslogtreecommitdiff
path: root/files/es/css_dinámico/index.html
blob: e77502cb7081c9972fe88bde84608245aa913bc4 (plain)
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
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
---
title: CSS dinámico
slug: CSS_dinámico
tags:
  - CSS
  - Todas_las_Categorías
---
<p>
</p>
<h3 id="Introducci.C3.B3n"> Introducción </h3>
<p>Tradicionalmente las páginas web se han dividido en dos categorías: estáticas y dinámicas. Hemos leído muchas veces que con <a href="es/XHTML">XHTML</a> y <a href="es/CSS">CSS</a> se pueden crear documentos de calidad, pero fijos, estáticos. Si quieres que tus páginas se adapten y cambien según las acciones del usuario, si quieres dinamismo, necesitas javascript o similares... Ya no.
</p><p>Si teniamos <a href="es/DHTML">DHTML</a> (html dinámico), ahora tenemos <b>CDSS</b> (<b>C</b>ss <b>D</b>inámico <b>S</b>in <b>S</b>cripts). Como en un cuento de hadas en el que un humilde sapo acaba siendo el príncipe de la historia, unas modestas pseudo-clases pueden acabar siendo las estrellas de la Web. </p><p>Las <a class="external" href="http://www.sidar.org/recur/desdi/traduc/es/css/selector.html#q15">pseudo-clases</a> en principio nacieron para darle dinamismo a los enlaces, y este es el uso que se les ha dado durante los últimos años. Es raro el archivo CSS que no incluya unas líneas semejantes a estas:
</p>
<pre>a:link { ... }
a:active { ... }
a:visited { ... }
</pre>
<p>¡Pero la situación ha cambiado! Ahora podemos aplicarle pseudo-clases a la mayoría de los elementos, y jugando con los selectores podemos crear documentos dinámicos usando exclusivamente CSS.
</p>
<h3 id="Poco_a_poco"> Poco a poco </h3>
<p>Lo veremos poco a poco y por medio de ejemplos centrados en la pseudo-clase :hover. Obviamente combinando diversas pseudo-clases pueden obtenerse efectos más complejos.
Para probar los ejemplos basta copiar y pegar el código (sin quitar ni añadir nada) en un archivo vacio y visualizarlo con el navegador. </p><p>Empecemos por el uso tradicional:
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

a:hover { color: red; }

&lt;/style&gt;

&lt;p&gt; Párrafo con &lt;a&gt;enlace&lt;/a&gt; que se pone rojo &lt;/p&gt;

</pre>
<p>Soltamos amarras, levamos 'anclas' y...
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

p:hover { color: red; font-variant: small-caps; }
li:hover { color: blue; background: silver; }
div:hover { color: orange; text-align: right; }

&lt;/style&gt;

&lt;p&gt; Párrafo que se pone rojo y mayúsculo. &lt;/p&gt;
&lt;ul&gt; &lt;li&gt; Item que se pone azul y con fondo gris. &lt;/li&gt; &lt;/ul&gt;
&lt;div&gt; División con texto que se flota a la derecha y se pone naranja. &lt;/div&gt;
</pre> <p>Esto nos permite crear con facilidad efectos dinámicos, podemos cambiar la visualización de las cosas dependiendo de los actos del usuario. Con un poco de imaginación y buen gusto se pueden hacer maravillas.
</p>
<h4 id="La_cosa_da_mucho_juego"> La cosa da mucho juego </h4>
<p>Podemos cambiar cualquier propiedad, pero no todas son igual de útiles a la hora de crear dinamismo. Algunas de las más interesantes serían por ejemplo: display, position, z-index...
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

.comun { position: absolute; width: 10em;
	 padding: 2em; text-align: center; }

#rojo { background-color: red;
        left: 1em; top: 1em;
        z-index: 1; }

#azul { background-color: blue;
        left: 5em; top: 5em;
        z-index: 2; }

#naranja { background-color: orange;
           left: 9em; top: 2em;
           z-index: 3; }

#rojo:hover,
#azul:hover,
#naranja:hover { z-index: 4; }

&lt;/style&gt;

&lt;p id='rojo'    class='comun'&gt;El rojo es vivo&lt;/p&gt;
&lt;p id='azul'    class='comun'&gt;El azul es elegante&lt;/p&gt;
&lt;p id='naranja' class='comun'&gt;El naranja es guay&lt;/p&gt;
</pre>
<h3 id="Pero_esto_no_es_todo.2C_a.C3.BAn_hay_m.C3.A1s."> Pero esto no es todo, aún hay más. </h3>
<p>Jugando con los <a class="external" href="http://www.sidar.org/recur/desdi/traduc/es/css/selector.html">selectores</a> podemos relacionar unos elementos con otros.
</p><p>Por ejemplo: al posicionarnos sobre <a href="es/HTML/Elemento/p">p</a> cambiamos las propiedades de <a href="es/HTML/Elemento/a">a</a>, y al posicionarnos sobre <a href="es/HTML/Elemento/a">a</a> cambiamos las propiedades de <a href="es/HTML/Elemento/em">em</a>.
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

em { display: none; }

p:hover a { color: red; }
a:hover em { display: inline; }

&lt;/style&gt;

&lt;p&gt; Párrafo &lt;a&gt;con enlace &lt;em&gt;que se pone rojo&lt;/em&gt; &lt;/a&gt; &lt;/p&gt;
</pre>
<p>Bueno, despues de unos ejemplos simples, uno un poco más complejo:
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

.editorial { width: 30%;}
.item { list-style: none; list-style-position: inside;
        padding: 0.2ex; margin: 0.2ex; }

a { color: darkblue; text-decoration: none;}
div:hover a { color: blue; text-decoration: underline;}

.oculto ul { display: none; }
div:hover ul { display: block; }

ul { border: transparent solid 0.1ex; }
ul:hover { border: peru solid 0.1ex; }

ul:hover abbr,
ul:hover dfn { color: red; }

.vista { visibility: hidden; }
ul:hover .vista { visibility: visible; }

&lt;/style&gt;

&lt;div class='editorial oculto'&gt;
   &lt;h2&gt; &lt;a&gt; CSS &lt;/a&gt; &lt;/h2&gt;
   &lt;ul class='item'&gt;
      &lt;li&gt; &lt;dfn&gt;CSS&lt;/dfn&gt; es una c seguida de dos eses. &lt;/li&gt;
      &lt;li&gt; También es un estándar del &lt;abbr&gt;W3C&lt;/abbr&gt;. &lt;/li&gt;
      &lt;li class='vista'&gt; No se me ocurre qué poner aquí. &lt;/li&gt;
   &lt;/ul&gt;

&lt;/div&gt;

&lt;div class='editorial'&gt;
   &lt;h2&gt; &lt;a&gt; HTML &lt;/a&gt; &lt;/h2&gt;
   &lt;ul class='item'&gt;
      &lt;li&gt; &lt;dfn&gt;HTML&lt;/dfn&gt; es un lenguaje para el marcado de hipertextos. &lt;/li&gt;
      &lt;li&gt; Es un estándar del &lt;abbr&gt;W3C&lt;/abbr&gt;. &lt;/li&gt;
      &lt;li class='vista'&gt; Creado por Tim Berners-Lee. &lt;/li&gt;
   &lt;/ul&gt;
&lt;/div&gt;
</pre>
<h4 id="Tipos_de_relaciones_familiares"> Tipos de relaciones <i>familiares</i></h4>
<p>Hasta el momento todos los ejemplos muestran relaciones padre → descendiente, si has consultado la especificación sabrás que no son las únicas, las posibilidades son las siguientes:
</p>
<h5 id="Padre_.E2.86.92_hijo"> Padre → hijo </h5>
<p>Esta relación se expresa por medio del combinador ("&gt;"), relaciona un elemento con sus descendientes directos. En el siguiente ejemplo seleccionamos los elementos con clase 'subrayado' que sean hijos directos de <a href="es/HTML/Elemento/div">div</a>
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

body:hover &gt; .subrayado { text-decoration: underline;}

&lt;/style&gt;

&lt;div&gt;
&lt;p&gt; Lo siguiente es una
 &lt;span class='subrayado'&gt;cita&lt;/span&gt;:
&lt;/p&gt;
&lt;hr&gt;
&lt;blockquote class='subrayado'&gt; &lt;p&gt;Si buscas resultados distintos, no hagas siempre lo mismo.
 &lt;cite&gt;Einstein&lt;/cite&gt; &lt;/p&gt;
&lt;/blockquote&gt;
&lt;/div&gt;
</pre>
<h5 id="Padre_.E2.86.92_descendiente"> Padre → descendiente </h5>
<p>Esta relación se expresa por medio de un espacio en blanco (" ") relaciona un elemento con un descendiente. Este es el método más flexible, puedes seleccionar cualquier elemento independientemente del parentesco exacto.
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

     p:hover em { visibility: hidden;}

&lt;/style&gt;

&lt;h2&gt; Selección de descendientes&lt;/h2&gt;
&lt;p&gt;
  &lt;em&gt;Este em es hijo de un párrafo&lt;/em&gt;
  &lt;span&gt; span tambien, pero...
     &lt;em&gt;Este em no es hijo de un párrafo, &lt;/em&gt;
     aunque sí descendiente (hijo de un hijo).
  &lt;/span&gt;
&lt;/p&gt;
</pre>
<h5 id="Hermano_.E2.86.92_hermano_.28adyacente.29"> Hermano → hermano (adyacente) </h5>
<p>Esta relación es expresa por medio del combinador ("+"), relaciona un elemento con su hermano adyacente (el inmediatamente siquiente). Este es el método aparentemente más limitado, pero el que abre más puertas.
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

#primero + li { list-style-type: none; }

&lt;/style&gt;

&lt;ul&gt;
  &lt;li id='primero'&gt;item 1&lt;/li&gt;
  &lt;li&gt;item 2&lt;/li&gt;
  &lt;li&gt;item 3&lt;/li&gt;
&lt;/ul&gt;
</pre>
<p><br>
Esto de relacionar hermanos está muy bien, pero solo se puede seleccionar el adyacente, esto es una limitación importante, pero bueno, siempre puedes seleccionar el adyacente del adyacente, o el...
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

#primero + li + li + li { list-style-type: none; }

&lt;/style&gt;

&lt;ul&gt;
  &lt;li id='primero'&gt;item 1&lt;/li&gt;
  &lt;li&gt;item 2&lt;/li&gt;
  &lt;li&gt;item 3&lt;/li&gt;
  &lt;li&gt;item 4&lt;/li&gt;
&lt;/ul&gt;
</pre>
<h5 id="Otros_parentescos"> Otros parentescos </h5>
<p>Padres, hijos y hermanos no son las únicas relaciones dentro de una familia. ¿Qué pasa si quiero seleccionar un nieto, o un sobrino? ¿Se puede? </p>
<dl><dt> Seleccionando un nieto
</dt><dd> No tiene mayor complicación, al fin y al cabo, un nieto no es más que un hijo de un hijo.
</dd></dl>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

p:hover &gt; span &gt; em { color: red; }

&lt;/style&gt;

&lt;p&gt;
 &lt;em&gt;este em es hijo de un párrafo&lt;/em&gt;
 &lt;span&gt; span también, pero...
   &lt;em&gt;este em es nieto&lt;/em&gt; &lt;/span&gt;
&lt;/p&gt;
</pre>
<dl><dt> Seleccionando un sobrino.
</dt><dd> No hay problema, un sobrino no es más que un hijo de un hermano.
</dd></dl>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

p:hover + div &gt; em { color: red; }

&lt;/style&gt;

&lt;p&gt;Al ponerte sobre este párrafo&lt;/p&gt;
&lt;div&gt; Cambias las propiedades de
   &lt;em&gt;este em&lt;/em&gt;
&lt;/div&gt;
</pre>
<h5 id="Limitaciones"> Limitaciones </h5>
<p>De los ejemplos anteriores se desprende que es muy fácil abarcar todas las combinaciones posibles. Siempre y cuando la secuencia de los selectores sea:
</p>
<ol><li>Descendente - Un elemento y sus descendientes.
</li><li>Horizontal - Un elemento y sus hermanos.
</li><li>Mixta - Una combinación de las anteriores.
</li></ol>
<p>Lo que no se puede hacer es seleccionar un ascendiente (ej. un padre). Por lo tanto <u>el siquiente ejemplo ni funciona ni debe hacerlo</u>:
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

em:hover #div { color: red; }

&lt;/style&gt;

&lt;h1&gt;Este ejemplo ni funciona ni debe hacerlo.&lt;/h1&gt;

&lt;div id='div'&gt;
   &lt;em&gt;Este em&lt;/em&gt;
   no puede cambiar las propiedades de su padre.
&lt;/div&gt;
</pre>
<p>Además hay una curiosa limitación ¿será un bug? Un selector compuesto puede empezar por un elemento o por un #id con :hover, Pero no puede empezar por una clase con :hover. Sorprendentemente con el selector universal (*) tampoco funciona.
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

* { color: red; }

  .uno       .cero { color: blue; }      /* esto sí funciona */
 *.uno       .cerocero { color: blue; }  /* esto sí funciona */

  #uno:hover .dos { color: blue; }       /* esto sí funciona */
ul.uno:hover .cuatro { color: blue; }    /* esto sí funciona */

  .uno:hover .tres { color: blue; }      /* esto NO funciona */
 *.uno:hover .cinco { color: blue; }     /* esto TAMPOCO funciona */

&lt;/style&gt;

&lt;div class='uno'&gt;
  .uno       .cero { color: blue; }
  &lt;em class='cero'&gt;Esto sí funciona,&lt;/em&gt; y... &lt;br&gt;
  *.uno       .cerocero { color: blue; }
  &lt;em class='cerocero'&gt;esto también funciona.&lt;/em&gt;
&lt;/div&gt;

&lt;ul id='uno' class='uno'&gt;
  &lt;li class='dos'&gt;#uno:hover .dos - esto sí funciona.&lt;/li&gt;
  &lt;li class='tres'&gt;.uno:hover .tres - esto NO funciona.&lt;/li&gt;
  &lt;li class='cuatro'&gt;ul.uno:hover .cuatro - esto sí funciona.&lt;/li&gt;
  &lt;li class='cinco'&gt;*.uno:hover .cinco - esto TAMPOCO funciona.&lt;/li&gt;
&lt;/ul&gt;
</pre>
<h3 id="Navegadores_que_lo_soportan">Navegadores que lo implementan</h3>
<p>Los navegadores pueden dividirse en dos grupos: IE y el resto.</p>
<ul> <li><strong>IE</strong>: IE6 no lo implementa, pero IE7 sí, aunque parece que sólo parcialmente... (probado en IE7 beta).</li> <li><strong>El resto</strong>: cada día son más los navegadores que implementan este uso de las pseudo-clases: <ul> <li>Firefox 1.5 - sí lo implementa, al igual que todos los navegadores basados en las últimas versiones de Gecko.</li> <li>Opera - sí lo implementa (pendiente de confirmación plena).</li> <li>Konqueror/Safari - sí lo implementa (pendiente de confirmación plena) al igual que todos los navegadores basados en las últimas versiones de KHTML.</li> </ul> </li>
</ul><h3 id="Referencia">Referencia</h3>
<p>Lo cierto es que no hay mucho escrito sobre el tema (en castellano casi nada, o nada), la gente sólo suele escribir sobre las cosas que funcionan en IE. Pero tampoco hace mucha falta. Todo lo que necesitamos está en <a class="external" href="http://www.sidar.org/recur/desdi/traduc/es/css/cover.html#minitoc">el estándar CSS-2</a>. Además, <em>curiosamente</em>, los dos pilares que sostienen esta funcionalidad (pseudoclases y selectores), están explicados en la misma página: <a class="external" href="http://www.sidar.org/recur/desdi/traduc/es/css/selector.html">el capítulo 5</a>.</p>
<p>Recomiendo encarecidamente la lectura completa y atenta de todo el capítulo, y ya puestos, de toda la especificación. Aunque para el asunto que nos ocupa nos interesan principalmente:</p>
<dl> <dd>Sobre los selectores por parentesco, sub-capítulos: 5.5, 5.6, 5.7</dd> <dd>Sobre las pseudo-clases, sub-capítulo: 5.11</dd>
</dl><h3 id="CSS-3"> CSS-3 </h3>
<p>Todo lo explicado es conforme a CSS-2.1 ¿Qué nos depara el futuro? Si los pilares de esta técnica son las pseudo-clases y los selectores, <a class="external" href="http://www.w3.org/Style/CSS/current-work">CSS-3</a> traerá muchas más <a class="external" href="http://www.w3.org/TR/2005/WD-css3-selectors-20051215/#pseudo-classes">pseudo-clases</a> y muchos más <a class="external" href="http://www.w3.org/TR/2005/WD-css3-selectors-20051215/#selectors">selectores</a>, en definitiva, muchas más posibilidades de hacer cosas interesantes.
</p><p>Por ejemplo, hemos visto las limitaciones de CSS-2 para seleccionar hermanos, con CSS-3 esta limitación desaparece. Lo siguiente es CSS-3 pero funciona (usando el navegador apropiado).
</p>
<pre>&lt;meta http-equiv='Content-Type' content='text/html; charset=UTF-8'&gt;
&lt;style type='text/css'&gt;

.gracias { visibility: hidden; }

#primero:hover + .gracias { visibility: visible; }
#primero:hover ~ * span { color: red; } /* esto:'~' es CSS-3 */

&lt;/style&gt;

&lt;ul&gt;
  &lt;li id='primero'&gt;Por favor, ponga el cursor encima de esta frase.&lt;/li&gt;
  &lt;li class='gracias'&gt;Le doy las gracias con CSS-2.1&lt;/li&gt;
  &lt;li&gt;Item normal y corriente&lt;/li&gt;
  &lt;li&gt;El futuro: &lt;span&gt;span en rojo gracias a CSS-3&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;
</pre>
<h3 id="Notas_finales"> Notas finales </h3>
<ul><li> Sí, es cierto que con <a href="es/JavaScript">JavaScript</a> o PHP pueden hacerse cosas mucho más avanzadas, pero aquí está la gracia del artículo, que sin necesidad de Javascript o PHP, solo con CSS, puede añadírsele mucho dinamismo a las páginas web.
</li></ul>
<ul><li> Este artículo es sólo una introducción al tema, por razones didácticas los ejemplos son premeditadamente simples y limitados a una sola pseudo-clase (:hover). Puede que en el futuro exista un <a href="es/CSS_Din%c3%a1mico_II">CSS Dinámico II</a> que profundice más en el tema, muestre el uso de otras pseudo-clases y ejemplos más complejos.
</li></ul>
<p><span class="comment">Categorías</span>
</p>