CSS Sprites技術(shù)不新鮮,早在2005年 CSS Zengarden 的園主 Dave Shea 就在 ALA 發(fā)表對(duì)該技術(shù)的 詳細(xì)闡述 。原先只在CSS玩家之間作為一種制作方法流傳,后來(lái)出來(lái)個(gè) 14 Rules for Faster-Loading Web Sites , 技術(shù)人員之間競(jìng)相傳閱,其中第一條規(guī)則Make Fewer HTTP Requests就提到CSS Sprites。于是這個(gè)小妖精就火了起來(lái),甚至出現(xiàn)了在線生成工具,勢(shì)不可擋也。近來(lái)國(guó)內(nèi)很多blog都提到CSS Sprites,最著名的例子莫過(guò)于 http://www.google.co.kr/ 下方的那幾個(gè)動(dòng)畫(huà)。最新發(fā)布的YUI中,也是使用到CSS Sprites,幾乎都有的CSS裝飾圖都被一個(gè) 40×2000的圖 包辦。社交大站Facebook最近也使用了一個(gè) 22×1150的圖片 承擔(dān)了所有icon.一時(shí)間,CSS Sprites無(wú)處不在。
原理
我們知道,自CSS革命以降,HTML傾向于語(yǔ)義化,在一般情況下不再在標(biāo)記里寫(xiě)裝飾性的內(nèi)容而是把呈現(xiàn)的任務(wù)交給了CSS。GUI是繽紛多彩的,少不了各種漂亮的圖來(lái)裝點(diǎn)。新時(shí)代的生產(chǎn)方式是,在HTML布滿各種各樣的鉤子(hook),然后交由CSS來(lái)處理。在需要用到圖片的時(shí)候,現(xiàn)階段是通過(guò)CSS屬性background-image組合background-repeat, background-position等來(lái)實(shí)現(xiàn)(題外話:為何我提現(xiàn)階段,因?yàn)槲磥?lái)瀏覽器若支持content則又新增另外的實(shí)現(xiàn)方法)。我們的主角是,你一定猜到了,就是background-position。通過(guò)調(diào)整background-position的數(shù)值,背景圖片就能以不同的面貌出現(xiàn)在你眼前。其實(shí)圖片整體面貌沒(méi)有變,由于圖片位置的改變,你看到只該看到的而已。就好比手表上的日期,你今天看到是21,明天看到是22,是因?yàn)樗膒osition往上跳了一格。所以你也大概了解到,CSS Sprites一般只能使用到固定大小的盒子(box)里,這樣才能夠遮擋住不應(yīng)該看到的部分。
我們使用YUI的sprite.png舉個(gè)例子,假如我們有這么一段代碼,max代表最大化,min代表最小化,我們需要給它們配上相應(yīng)的漂亮圖片(這樣我們的網(wǎng)站才能夠吸引人,才可以賣(mài)錢(qián),才可以到佛羅里達(dá)曬太陽(yáng):D):
<div class="max">最大化</div>
<div class="min">最小化</div>
這兩個(gè)class都使用同一個(gè)圖片:
.min, max {
width:16px;
height:16px;
background-image:url(http://developer.yahoo.com/yui/build/assets/skins/sam/sprite.png);
background-repeat: no-repeat; //我們并不想讓它平鋪
text-indent:-999em; //隱藏文本的一種方法
}
效果如下: