如何使用css sprites把很多小圖放在在一張圖片上

來源:互聯網
上載者:User
這篇文章主要介紹了關於如何使用css sprites把很多小圖放在在一張圖片上,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

網頁製作Webjx文章簡介:在google中搜尋一下css sprites這個名稱,會查出很多資訊,並且隨著SEO越來越被人們重視,採用這種技術來進行圖片最佳化的網站越來越多,國內幾家大型門戶網站無不仿效。如新浪,網易,搜狐。你下載一下他們的網站上的圖

在google中搜尋一下css sprites這個名稱,會查出很多資訊,並且隨著SEO越來越被人們重視,採用這種技術來進行圖片最佳化的網站越來越多,國內幾家大型門戶網站無不仿效。如新浪,網易,搜狐。你下載一下他們的網站上的圖片,你會看到他們將很多小圖片全部整合在一張圖片上

在google中搜尋一下css sprites這個名稱,會查出很多資訊,並且隨著SEO越來越被人們重視,採用這種技術來進行圖片最佳化的網站越來越多,國內幾家大型門戶網站無不仿效。如新浪,網易,搜狐。你下載一下他們的網站上的圖片,你會看到他們將很多小圖片全部整合在一張圖片上
這樣做的好處是不言而語:

  1. 加速圖片顯示 利用CSS技巧減小HTTP請求 利於網站最佳化seo

其實原理非常簡單,主要是應用css中的背景定位技術來實現的。主要就是用一個屬性background-position來控制顯示一張大圖片中的一個指定大小的圖片位置。
css sprites圖片背景最佳化技術
下面從一個比較有趣的例子來一步步動手製作一幅撲克牌,看看是如何定位元影像片的。
首先我們分析一下撲克牌,一幅撲克牌有兩種顏色,有四種圖案黑桃、紅心、梅花、方塊。另外有J,Q,K,這三種是花牌。A~10中只用到四種圖案,而三種花牌用到三張圖片,而它們的位置是不同的,但歸納起來就只有幾種變化,如A—7這是一種變化,它是三行三列的布局(A和2是它的特例),8—10就一種,它是四行三列。J,Q,K是一種(其實它也是第一種的變種特例)。
知道了原理就好辦了,我們先做出它們的圖片來,一張一張來,黑桃、紅心、梅花、方塊大圖各一張,小圖各一張,J,Q,K圖案各一張,背景圖一張。
另外要做全部的數字圖片13張,270度翻轉的圖片13張。
好了,所有的圖片準備齊了,共有71張圖片,嘿嘿,有點嚇人,這麼多圖片,沒想到吧(以後會介紹一個比較省事的做法,不用圖片,先賣個關子,有點)
我們以黑桃10為例看看其中的座標點,是在PS中用輔助線做好的效果:

圖一
要注意的是每一張牌下部分的內容與上部分是垂直翻轉的,這也是為什麼將數字也做成圖片的原因。
所以我們可以將所有的圖片在PS中排列組合在一起,二所示:

圖二
在組合這張圖片要注意的是,每一張圖都是完整的,不能被其它圖片重疊,並且要精確計算好每個圖片的座標位置,比如它的左上方頂點座標,和右下角頂點座標,知道這兩個座標點後,每一張小圖片的位置就能全部計算出來了。
圖片準備好了後,我們開始設計結構吧,因為黑桃10是所有撲克牌中用到圖片最多的,我們就以它為例。
HTML結構:

CSS樣式:

我先定義一張撲克牌的總容器的樣式:

.card{width:125px;height:170px; position:absolute;overflow:hidden;border:1px #c0c0c0 solid;}

我給它設定固定的寬高值,並加上一個邊框線,設定其絕對位置是為以後定位時打下伏筆。因為我可能會做不只一張撲克牌。以後在擴充時只需要給它加上left和top屬性就可將它定位到不同的地方。並且將它設定絕對位置後,其子容器又可以針對它來定位。
我用span,b,em三種標籤分別代表三種不同類型的圖片,span用來表標中間的圖片,b用來表示數定,em用來表示數字下面的小表徵圖。

上面的每個span代表一個座標點,將通用的部分寫成一個樣式,便於其它結構的調用,然後將它組合應用到一個座標點上,如<span class="A1 up1"></span>。

其樣式如下定義:

span{display:block;width:20px;height:21px; osition:absolute;background:url(images/card.gif) no-repeat;}

上面這個樣式是定義中間的10個黑桃圖片容器的通用設定。將它們設定為塊狀,並固定大小,設定其絕對位置,讓它能定義到你想指定的位置上。

.A1{left:20px;top:20px;}

這個樣式就是定位器,位移到指定的座標點上,其它的9個原理相似。

.up1{background-position:0 1px;}/*黑桃*/.down1{background-position:0 -19px;}/*垂直翻轉的黑桃*/

這兩個樣式就是載入圖片,因為每張片的在原圖上的座標位置是不同的,所以你要根據前面的圖片的位置找出每一個小圖片的精確位置。
現在,你已經構建了html結構,並給結構設定了樣式,將所有內容拼裝起來,我們的黑桃10就算完成了,簡單吧!
好了,一張撲克牌完成,其它的撲克牌觸類旁通。
我們還要加一張圖片來實現撲克牌翻過來的效果。這張圖片因為要進行平鋪,所以不加在上面的圖片集合。

最後,將所有內容綜合起來,一幅完整的撲克牌就算完成了!

以上就是本文的全部內容,希望對大家的學習有所協助,更多相關內容請關注topic.alibabacloud.com!

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.