教你如何用CSS Sprites(图片合并)技术切图
分类:网页设计 Tags: css 图片 评论:1 浏览:7455 最近更新时间:2010/1/2 15:35:21
众所周知,减少网站加载时间的最有效的方式之一就是减少网站的HTTP请求数。实现这一目标的一个有效的方法就是通过CSS Sprites——将多个图片整合到一个图片中,然后再用CSS来定位。
下面是一张样图:

本文的目的并不是讲CSS Sprite如何让一个网站更快,而是说一些使用CSS Sprite的时候的一些最佳实践。
不要等到你完成切片之后才开始sprite.
如果你边切图边写CSS,然后等你完成了整个网站之后再来拼接这些图片到一个Sprite中,你就不得不完全重写你的CSS,你也必须要花费很多的时间来用PS拼接大量的图片——这是件令人倍感纠结的事情。但是如果边切图边整合,就会比较容易些。
把图片放到它要显示的地方的相对的地方
这个小技巧貌似比较难理解。我直到创建一个比较大的sprite的时候才理解到这一点。比如,如果我们希望一个图片出现在一个元素的左侧:
![]()
将那个图片放到sprite图片的右边(本文开始的那个sprite图片)。这样的话,当你通过CSS移动背景图片的位置的时候,基本上不可能有其它的小图片意外的出现在它的附近。使用Sprite的时候常常遇到的一个问题是图片会出现在它不该出现的位置。
定位时避免使用bottom或right等
当使用CSS sprite的时候,只用background-position: bottom -300px或background-position: right -200px;非常容易。这刚开始的时候是可行的,但是问题是,当你在宽度上或高度上扩展相关sprite图片的时候,原先设置的位置可能是错的,因为那个图片已经不再Sprite图片的底部或右部了。使用确切的位置来避免这个问题。
给每个图片足够的空间
就像你在本文顶部的实例图片看到的那样,那些小图片都被预留了足够的空间。为什么不把他们塞到一块来让sprite图片更小呢? 因为使用这些图片的元素通常都会有大量的内容而且可能会需要扩展的间距,以至于其它图片不会意外出现。
例子:

例子中的每个条目都有个带数字的图片作为背景图片。如果你仔细看了上面的那张图片,你可以看到这三个数字图片是如何错开排列的,这样如果内容增多,其它图片就不会意外出现。
不用担心Sprite图片的像素大小
如果你的网站经过良好的设计,那么你将会有一大堆的图片来整合进到sprite里面,这样你就需要你个非常大的sprite来恰当的放置这些图片。这是很不错的。sprite里的空白不会占用太多的文件大小。addons.mozilla.org上使用的Sprite图片有1,000px×2,000 px那么大,但是图片的大小仅仅16.7kb!
简单介绍一下 CSS Sprites 的优点:
当用户往U盘中拷200张图片,会等很久。但是如果弄成一个文件,再拷贝就会快很多。
CSS Sprites 的目的就是通过整合图片,减少对服务器的请求数量,从而加快页面加载速度。

实现方法:
- 首先将小图片整合到一张大的图片上
- 然后根据具体图标在大图上的位置,给背景定位。background-position:-8px -95px;
-
• 网页复制文章自动添加版权信息代码
• 网页设计中HTML常范的几个错误,平常设计中需要注意了!
• JavaScript特效:实现上下文字、图片滚动循环显示,中间有停顿
• 支持支付宝付款的国外空间商
• 在Dreamweaver 8中自定义连接字符串代码
• Div+CSS网页布局入门实例教程四(图)
• Div+CSS网页布局入门实例教程一、二(图)
• Access数据库转SQL Server2000数据库的方法及经验总结
• 网页meta详解,制作网页的来了解下!
• 关于xp for iis5.1提示连接数据库失败解决方法
-
• 怎样在电脑上浏览WAP网站网页,下载网站里面的软件、游戏、玲声、电子书、电影、图片等!
• 做小语种外贸网站有哪些好处
• 兼容ie,火狐,chrome,safari,360,qq,遨游,搜狗等浏览器的设为首页和加入收藏代码
• 通过css代码做Table表格隔行变色效果
• 利用ASP显示当前网站在线人数代码
• fckeditor报错FCKLang undefined(fcklang未定义)的解决方法
• 十个增强英文外贸购物网站信任度的认证
• ASP编程中经常用到的ASP代码,很有用的哦
• EASEUS Partition Master 5.0.1 Unlimited Edition无损磁盘分区调整工具教程
• Div+CSS网页布局入门实例教程三(图)