Je suppose que vous parlez de sprites CSS. Voici un article A List Apart pour vous aider à démarrer: http://www.alistapart.com/articles/sprites. L'idée de base est que toutes vos images sont combinées en une seule grande image.
Alors que normalement vous aurez img
étiquettes ou petits éléments avec l'image de fond appliquée, vous avez maintenant l'image unique appliquée à plusieurs éléments comme image de fond, et chacun d'eux a différentes valeurs de position de fond pour positionner l'image correcte . Un exemple de ceci serait les icônes de jQuery UI - l'apparence d'une seule image combinée comme ceci:
Ensuite, chacune des icônes individuelles partagent une seule classe, avec un ensemble backgroun-image
:
.ui-icon{width:16px;height:16px;background-image:url(../images/ui-icons_808080_256x240.png);}
en plus background-position
personne pour chacune des différentes icônes:
.ui-icon-carat-1-n{background-position:0 0;}
.ui-icon-carat-1-ne{background-position:-16px 0;}
.ui-icon-carat-1-e{background-position:-32px 0;}
.ui-icon-carat-1-se{background-position:-48px 0;}
La même chose peut être fait pour e e états interactifs individuels: modifiez la position de fond de l'élément sur :hover
et vous obtenez une couleur ou une icône différente.
Excusez-moi, mais ce que voulez-vous dire exactement par le terme « image HTML », parce que je suppose, la solution triviale en utilisant le « fond » attribut de CSS pour différents styles n'est pas ce que vous cherchez. – ofi