En este tip les mostraré cómo crear un menú hecho sólo a base de imágenes, precargadas (sin javascript) y amigable con los buscadores. Este método se llama CSS Sprites, y lo recomiendo muchísimo a todos porque yo estoy segura que a más de uno le ha pasado que cuando pasan el mouse sobre un menú que es de imágenes o que tiene una imágen de fondo, se debe esperar 1 o 2 segundos a que la imágen del rollover cargue. Eso en lo personal me parece molesto porque interfiere en mi experiencia de usuario; al precargar las imágenes le ofrecemos al usuario una experiencia más placentera. Y más adelante les mostraré cómo este método también es muy útil para Aplicaciones Web cuya presentación es en html/xhtml, así que a los desarrolladores les va a interesar puesto que optimiza la carga de aplicaciones.
Los Sprites
Primero ¿qué son los Sprites? Si dan una búsqueda por Google verán que se trata de una gran imagen que contiene más imágenes pequeñas dentro. Los Sprites eran usados en los videojuegos antiguos de 2D, esos que tenían pocos colores, para tener cargados a sus personajes y mediante sus algoritmos de programación se movían dentro de esta gran imágen y daba como resultado el personaje moviéndose, corriendo, etc. Este es un ejemplo de sprites del famosísimo juego Mario Bros:

Pueden leer mas sobre la definición de sprites en Wikipedia http://es.wikipedia.org/wiki/Sprite_(videojuegos)
Entonces ¿que tienen que ver los sprites con CSS? Bastante, pues les diré que esta antigua técnica nos ayuda a nosotros los diseñadores y/o desarrolladores a optimizar la carga de nuestras páginas web, y se los voy a demostrar con el ejemplo de crear un menú.
Preparando la imágen
Esta es la parte más importante, es lo que nos dará esa precarga de imágenes que queremos.
Volviendo al concepto de Sprites, lo que nos quiere decir es que en una imágen se tienen todas las imágenes que se usarán, para este caso, en una sola imágen tendré todos los estados del menú, el estado normal, el sobre o rollover, y el activo.
La siguiente es la imágen que usaré para mi ejemplo:

La imágen real tiene una dimensión de 702px de ancho x 108px de alto y pesa 9.21KB, la primera sección es el estado normal, la del medio es el rollover y el último es el estado activo, el que me dice en qué sección de la página estoy.
El menú en la página web tendrá solamente 36px de alto, entonces como se habrán dado cuenta si separan cada sección de la imagen, cada una es de 36px de alto, 36*3=108px
Esa es la idea, cuando ustedes empiecen a cortar su diseño, coloquen en un solo archivo todos los estados de su menú.
Hay que tomar nota del ancho para cada botón en esa imágen, yo usé las guías del photoshop y a partir de ahí medí el ancho para cada botón.

Preparando el XHTML
Entonces creamos la clásica lista para nuestro menú.
Código :
<ul class="menuholder"> <li class="menu_intro"><a href="#" title="Introduction" class="active">Introduction</a></li> <li class="menu_book"><a href="#" title="The Book">The Book</a></li> <li class="menu_testi"><a href="#" title="Testimonials">Testimonials</a></li> <li class="menu_what"><a href="#" title="What You Will Get">What You Will Get</a></li> <li class="menu_buy"><a href="#" title="Buy Now">Buy Now</a></li> </ul>
Notar que cada link tiene su respectivo atributo title y que se ha mantenido el texto dentro del link <a>, esto es para que sea accesible y amigable con los buscadores.
Es importante que cada <li> llame a una clase distinta, y colocar una clase llamada "active" a la opción del menú que se desea mostrar como activa.
Y bueno como ven la parte del html es la más fácil no hay mucha ciencia, ahora pasaremos a la hoja de estilos.
El CSS
OK, primero asegúrense de tener un Reset en su archivo CSS. Para fines de este tip usaré el siguiente:
Código :
* {margin:0px;padding:0px;}
ul,li {list-style-type:none;}
Ahora vamos a definir ciertos parámetros para la clase "menuholder" que es el <ul> que encierra el menú
Código :
.menuholder {background:url(images/bgmenu.gif) #dd0069;} /*opcional*/
.menuholder li {float:left;}
.menuholder a {background:url(images/menu-options.gif);display:block; height:36px; text-indent:-9000%}
En la primera línea estoy colocándole un fondo fucsia con una pequeñísima imágen de 1px de ancho por 36px de alto. Esto es para que salga de frente un fondo fucsia en mi menú rápido mientras cargan la imágen del menú. Esto es opcionanal pero la considero una buena práctica.
En la segunda línea hago que los elementos <li> dentro de .menuholder tengan float:left para que salgan todos en fila, en una sola línea, ya no como una lista hacia abajo.
En la tercera línea finalmente vemos que todos los links <a> dentro de .menuholder tendán de imágen de fondo menu-options.gif que es nuestra gran imagen con todos los estados. Se le define un display: block para que se le puedan aplicar el ancho y el alto a cada link, lo que sigue justamente es el alto de 36px ya que cada link tiene el mismo alto lo ponemos aquí y el text-indent moverá el texto dentro de los links bien lejos para que no se vean sobre el menú.
Ahora sí viene lo bueno, este es resto del CSS, que se encargará de posicionar la imágen de fondo en cada estado del menú:
Código :
/*ESTADO NORMAL*/
.menu_intro a {width:155px;}
.menu_book a {width:107px; background-position:-155px 0px;}
.menu_testi a {width:134px; background-position:-262px 0px;}
.menu_what a {width:176px; background-position:-396px 0px;}
.menu_buy a {width:130px; background-position:-572px 0px;}
/*ESTADO ROLLOVER*/
.menu_intro a:hover {background-position:0px -36px;}
.menu_book a:hover{background-position:-155px -36px;}
.menu_testi a:hover {background-position:-262px -36px;}
.menu_what a:hover {background-position:-396px -36px;}
.menu_buy a:hover {background-position:-572px -36px;}
/*ESTADO ACTIVO*/
.menu_intro a.active {background-position:0px -72px;}
.menu_book a.active {background-position:-155px -72px;}
.menu_testi a.active {background-position:-262px -72px;}
.menu_what a.active {background-position:-396px -72px;}
.menu_buy a.active {background-position:-572px -72px;}
¿Recuerdan que tomamos nota de los anchos? Bueno aquí es donde se usan, en la primera sección donde están los estados normales, se especifica el ancho de cada link, notar que estoy poniendo el nombre de la clase y luego la etiqueta de link <a>, porque es al link que esta dentro de la clase al que estoy aplicando todas estas definiciónes. Luego juego con la posición del fondo, como ven sólo estoy moviendo las posiciónes horizontales (eje X), en el primero no le especifiqué porque un fondo por defecto esta en la coordenada 0,0 así que no es necesario escribir la posición en este caso en particular.
Para el estado rollover muevo todos los backgrounds en el eje Y a -36px para que pase a la sección media de la imágen donde están todas mis imágenes de rollover, las posiciónes horizontales se mantienen.
Y por ultimo el estado activo, muevo los backgrounds 36px más, es decir -72px en el eje Y para que se puedan ver los estados activos, y nuevamente mantengo los del eje X. Notar que la etiqueta <a> esta definiendo una clase "active" esto se coloca en el link <a> que se desea mostrar activo y en este caso es el primer botón del menú. ¡Y ya está!
Eso es todo, espero que hayan entendido, pueden ver el ejemplo en línea y descargar este ejemplo (notar que no hay retraso al mostrar las imágenes del menú)
Ver ejemplo online
Descargar archivos
Tip para desarrolladores
Este método no se limita solamente a menús en páginas web, esto ayuda bastante en la optimización de aplicaciones web también, ya que evitamos constantes conexiones al servidor cada vez que se necesite un icono, imágen, fondo, etc. Las aplicaciones web utilizan bastantes iconos, les pongo el ejemplo de Yahoo! Mail, ellos usan este método para sus iconos y fondos de los tabs, esta es una pequeñísima parte de la gran imagen que ellos usan para sus iconos, la original es de 3050px de ancho x 101px de alto, y pesa tan sólo 31kb:

Y usan otra gran imágen para el fondo de sus tabs también.
Como ven este método es muy útil, úsenlo sabiamente donde lo vean necesario, especialmente en imágenes estáticas que saben que van a ser llamadas una y otra vez.
Espero que esta información les sirva para proyectos futuros

He útilizado ésta tecnica sólo una vez para un "star rating" pero veo qué tiene un muy buen uso para otras cosas. y eso de una sola imagen para todos los iconos es algo que desconocía y qué a su ves es genial; lo tomaré en cuenta para futuros proyectos.
¡Gracias por el tip, drarock!
Muy, muy buen tip.
Gracias por el tip
Por Lunatic el 18 de Diciembre de 2008
Muy buen tip
Por GABI el 22 de Diciembre de 2008
Por bioquimic el 28 de Diciembre de 2008
Gracias por el aporte.
Por Laupi! el 09 de Enero de 2009
Por GUSTAVO CASTRO el 22 de Enero de 2009
Por Chris el 06 de Abril de 2009
El problema que le veo es con IE8: Si lo testeas en él veran como el enlace inicio aparece sobre la imagen utilizada para los botones.
¿como se soluciona esto con esta nueva version de IE8? Saludos!
Por kevin el 15 de Abril de 2009
Muy buen tip
Thariamon :
M@U :
Gracias por la bienvenida M@U
No había leído la parte en que mencionan 100pxs
Corregido
Por Matias el 29 de Junio de 2009
Por Rulo el 25 de Julio de 2009
Por Fio el 06 de Octubre de 2009
Aplique esta técnica y resulto genial, pero tengo el mismo problema que cito Chris-blog.
En IE 8 y 7 se ve el texto del link "inicio".
En Firefox funciona perfecto.
Como se puede corregir? Gracias!
Por Good tuto el 09 de Noviembre de 2009
Mil gracias.
Por Enrique Robledo el 17 de Noviembre de 2009
El problema de las letras apareciendo sobre la imagen en IE8 se soluciona muy simplemente, cambiando el
text-ident: -9000%
por
text-ident: -6000px; (o la cantidad de -XXXpx que quieran)
Por Robert el 09 de Diciembre de 2009
Por Marina el 21 de Enero de 2010
Por Songoku el 14 de Junio de 2010
Por favor dediquenle mas tiempo a programar para Browsers de verdad como Firefox, Opera y Chrome(Windows y Linux) y Firefox y Safari(Mac) ya que ellos si respetan los estandares.
Muchas Gracias.
Por AlxsBC el 15 de Agosto de 2010
Amigo, no es que llamemos mal a IE, pero como desarrolladores web debemos probar en todos, y más si IE es uno de los más usados.
Por cierto, a mi me funcionó el truco de cambiar el -9000% por -1000px
Por Rodrigo el 02 de Noviembre de 2010
Por RAFAEL el 25 de Marzo de 2011
Por DxMax el 28 de Marzo de 2011
Por oahb0402 el 05 de Abril de 2011
Por Bernar el 26 de Abril de 2011
Por edgardo el 08 de Noviembre de 2011
Por lester el 18 de Noviembre de 2011
Por lester el 23 de Noviembre de 2011
lo explico claramente aqui: "..........Es importante que cada <li> llame a una clase distinta, y colocar una clase llamada "active" a la opción del menú que se desea mostrar como activa.........."
jeje cosas de principiante muy bueno el tutorial funciona 100% gracias nuevamente un saludo
Por Tobani G. el 26 de Enero de 2012