你的位置:齐鲁公社 >> 科教 >> 电脑网络 >> 网页设计 >> 详细内容 在线投稿

CSS Sprites对CSS布局的意义、优点和缺点介绍

99书城会员招募      特惠酒店,尽享关怀
排行榜 收藏 打印 发给朋友 举报 来源: 中国站长站   发布者:webmaster
热度79票  浏览484次 【共0条评论】【我要评论 时间:2008年7月13日 20:42
齐鲁公社j-Iz1JS4R+|#y

CSS Sprites技术早在2005年 CSS Zengarden 的园主 Dave Shea就在ALA发表对该技术的详细阐述。

e? f AK&J @m0

2`yp:mj {4a0原先只在CSS玩家之间作为一种制作方法流传,后来出来个14 Rules for Faster-Loading Web Sites,技术人员之间竞相传阅,其中第一条规则Make Fewer HTTP Requests就提到CSS Sprites。于是这个小妖精就火了起来,甚至出现了在线生成工具,势不可挡也。近来国内很多blog都提到CSS Sprites,最著名的例子莫过于 google.co.kr 下方的那几个动画。最新发布的YUI中,也是使用到CSS Sprites,几乎都有的CSS装饰图都被一个40×2000的图包办。社交大站Facebook最近也使用了一个22×1150的图片承担了所有icon。一时间,CSS Sprites无处不在。

5}U)I,G[#k0B {7`0 齐鲁公社eg$d VN.}e

CSS Sprites工作原理齐鲁公社C `R'uS:P~|%m

齐鲁公社iy3PRB.r6Yo{

我们知道,自CSS革命以降,HTML倾向于语义化,在一般情况下不再在标记里写装饰性的内容而是把呈现的任务交给了CSS。GUI是缤纷多彩的,少不了各种漂亮的图来装点。新时代的生产方式是,在HTML布满各种各样的钩子(hook),然后交由CSS来处理。

&b9O kMq{0 齐鲁公社,e|*X)m#^e(o3G

在需要用到图片的时候,现阶段是通过CSS属性background-image组合background-repeat, background-position等来实现(题外话:为何我提现阶段,因为未来浏览器若支持content则又新增另外的实现方法)。我们的主角是,你一定猜到了,就是background-position。通过调整background-position的数值,背景图片就能以不同的面貌出现在你眼前。其实图片整体面貌没有变,由于图片位置的改变,你看到只该看到的而已。就好比手表上的日期,你今天看到是21,明天看到是22,是因为它的position往上跳了一格。所以你也大概了解到,CSS Sprites一般只能使用到固定大小的盒子(box)里,这样才能够遮挡住不应该看到的部分。齐鲁公社fI|:Y#F

齐鲁公社@(I!j!k6O6|O.J'M0AK

我们使用YUI的sprite.png举个例子,假如我们有这么一段代码,max代表最大化,min代表最小化,我们需要给它们配上相应的漂亮图片(这样我们的网站才能够吸引人):

!g}[/Nz0

3?7XrW@"o9XC0

<div class="max">最大化</div>
9V7[r'D"hn6pc U0<div class="min">最小化</div>

-y }%Y|J6I d B/o0 齐鲁公社wrp+_:G G,^P!i

这两个class都使用同一个图片:齐鲁公社b0c@0LWG%I

 

sHcfM+^NW$x0

p/n4^-{&t+yL0 

.min, .max {
JCG Y0L@;f(d0  width:16px;齐鲁公社#^ D'P*u'HNtz7W-Z+f
  height:16px;齐鲁公社 _ zHL$]B Y
  background-image:url(sprite.png);齐鲁公社]~#B9b0}.k.|(_&hx-o
  background-repeat: no-repeat; /*我们并不想让它平铺*/
$qj}mzo%K0h3r^z0  text-indent:-999em; /*隐藏文本的一种方法*/齐鲁公社!S;^0}K~:}
}

CvO'Gp8U5dl^X5r0

~K*oE/[P0

$zd.h A y!kB6o0<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">齐鲁公社b8V n(Nd|&_pN
<html xmlns="http://www.w3.org/1999/xhtml">齐鲁公社e#m"q a0XviN
<head>齐鲁公社/^:a7v+J~3S'l6a$@S,`
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />齐鲁公社J l|%GJa+_8b&p%y
<title>CSS Sprites工作原理及其对CSS布局的意义、优点和缺点介绍</title>齐鲁公社u;lXDJ-Z7zL
<style type="text/css">
&[4a|.y'~ xR1[0.min, .max {齐鲁公社$^ni*X3n-|s
  width:16px;齐鲁公社-_{6i3cJDU0kC
  height:16px;
o/H%]'Bi"By'U(Js0xs0  background-image:url(attachments/month_0805/4200859125518.png);
,b5G;X3?4Bwn0  background-repeat: no-repeat; /*我们并不想让它平铺*/
KVANPLo(t'i0  text-indent:-999em; /*隐藏文本的一种方法*/
MG~j]&@m A0}齐鲁公社;G ` G%h6C
</style>齐鲁公社x*[4DLz)H6h
</head>齐鲁公社"Z?sf$qR p

齐鲁公社,p Q&?? w n-XJC

<body>齐鲁公社0o_l'ay
<div class="max">最大化</div>齐鲁公社5] _(g1qsvNa1O
<div class="min">最小化</div>
!h v\rR+V5uC0</body>
jyD1}/Q(xFM;F0</html>

-]xa?U/@ `3\0

8p^QzgI1R0 齐鲁公社~'gxca!O

我们看到一团灰,没错,因为我们还没有指定background-position,默认为 0 0,可以看下sprite.png,处于这个位置正是灰块。好了,我们要找到代表最大化的加号和代表最小化的减号的位置找出来。经过测量,最大化按钮位于Y轴的350px处,最小化按钮位于Y轴400px处。想一想我们如何才能让它们能够显示出来呢,明显,要向上提升sprite.png,得到代码如下:齐鲁公社vFZ}%b1F

齐鲁公社 Lc4E4{0O`3C-C

.max { background-position: 0 -350px;}
\]HKC4y0.min { background-position: 0 -400px;}

jU A5f$s:A P0

A8Ny X$~'~0<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
&O"?:p4c^4K8M*C0<html xmlns="http://www.w3.org/1999/xhtml">
Jc.DAl1Y @Vwk0<head>齐鲁公社s%r,\h)a P.M,]
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
0K P.po ?1u0<title>CSS Sprites工作原理及其对CSS布局的意义、优点和缺点介绍</title>齐鲁公社7HP_+Nh,}G8ND6Y
<style type="text/css">齐鲁公社e0Kig!A`
.min, .max {
+y/]&Z5d'~`?X0  width:16px;齐鲁公社~&g j"c*^3P)d$t6w(gJ
  height:16px;齐鲁公社\Q `a+zF1oCh O
  background-image:url(attachments/month_0805/4200859125518.png);
M[9J4?5nrs2O`"Z'Jx4V0  background-repeat: no-repeat; /*我们并不想让它平铺*/齐鲁公社+E0u9ZE H_
  text-indent:-999em; /*隐藏文本的一种方法*/齐鲁公社w\7a:W)u$O5tY2?7tl
}齐鲁公社|3X o*up*S3p&C/H|^)h
.max { background-position: 0 -350px;}
4z!A/dhtv:J0.min { background-position: 0 -400px;}齐鲁公社m O1n${ E;UI
</style>齐鲁公社 ]W[jn#b8P.MS7j N
</head>

9p/S7H7SHQ"[C0 齐鲁公社L1|p4pPKv+yg

<body>齐鲁公社PF5k)m(a|
<div class="max">最大化</div>齐鲁公社wv\j#Cw b)f1x r
<div class="min">最小化</div>
i/Lv4Yo4V x&s0</body>齐鲁公社r U"|c%N4e
</html>齐鲁公社j!`;Z JBa9mY t

齐鲁公社:u @e)e'N

这一次我们成功了!齐鲁公社LA*X~9r,oP K

mq6OB4_0CSS Sprites优点

(k Ca0s*M?#[?M8i2m;_0 齐鲁公社OeO!{-Q*Xc

我们从前面了解到,CSS Sprites为什么突然跑火,跟能够提升网站性能有关。显而易见,这是它的巨大优点之一。普通制作方式下的大量图片,现在合并成一个图片,大大减少了HTTP的连接数。HTTP连接数对网站的加载性能有重要影响。

@w(hr3eL)O(F.{+L m ~0

]5V-S4OmV#[0CSS Sprites缺点齐鲁公社.a.XyJ R:yo

(V/Q5Tm {6b2qQ0至于可维护性,这是一般双刃剑。可能有人喜欢,有人不喜欢,因为每次的图片改动都得往这个图片删除或添加内容,显得稍微繁琐。而且算图片的位置(尤其是这种上千px的图)也是一件颇为不爽的事情。当然,在性能的口号下,这些都是可以克服的。

^!W `|eZ8K p `0

f z_k Cc ^rDVP0由于图片的位置需要固定为某个绝对数值,这就失去了诸如center之类的灵活性。齐鲁公社$g1H'Z-QP1H-T

wrO1nJwC0前面我们也提到了,必须限制盒子的大小才能使用CSS Sprites,否则可能会出现出现干扰图片的情况。这就是说,在一些需要非单向的平铺背景和需要网页缩放的情况下,CSS Sprites并不合适。YUI的解决方式是,加大图片之间的距离,这样可以保持有限度的缩放。齐鲁公社v#c;K@(LQ9qga

齐鲁公社 _`6S5LIz$tC

CSS Sprites总结
A;zLV)UD)G:X%f0
4i.j1U'Oj(W%i D0
性能压倒一切。CSS Sprites是值得推广的一种技术。尤其适宜用于FIR,比如固定大小的icon替换。为保持兼容性,图片中的各个部分保持一定的距离是一种不错的做法。

3]7{[@C[z0
顶:22 踩:20
【已经有35人表态】
6票
感动
2票
路过
4票
高兴
4票
难过
6票
搞笑
4票
愤怒
3票
无聊
6票
同情
上一篇 下一篇
查看全部回复【已有0位网友发表了看法】

网络资源

合作伙伴