When using CSS image rollovers, two, three, or more images must be loaded (and often be preloaded for best results). We've got one image for each state (normal, hover, active, visited etc). Putting all states into one image makes dynamic changes faster and requires no preload.
Let's have a simple example. The menu items are the a-elements with
Fig. 1: Three states together in one imageUsually, in CSS rollovers, we use background images in this way:
Let's have a simple example. The menu items are the a-elements with
display:block
. Proper padding and background image for a
, a:hover
and a:active
make the rollover. To simplify the rollover, I used only one picture containing three states of a button — normal, :hover, and :active.Fig. 1: Three states together in one image
#menu a { ... background: url("button.gif") top left no-repeat; } #menu a:hover { ... background-image: url("button-over.gif"); } #menu a:active { ... background-image: url("button-active.gif"); } /* etc... */
Using one common picture, we don't need to change the background image. We just change its background-position. The :hover state will use the background image moved proper count of pixels (in the example the shift is 157px to the left), the :active state will use bigger shift (by 314px in the example).
#menu a { background: url("button.gif") 0 0 no-repeat; ... } #menu a:hover { background-position: -157px 0; ... } #menu a:active { background-position: -314px 0; ... }
That's all. Just one image is used. No preload is needed. State switching is as fast as possible (moving background position is much faster than replacing background image). AFAIK, it works in every CSS2 capable browser (IE5+, Mozilla, Opera, Safari etc.)
No hay comentarios:
Publicar un comentario