关于CSS精灵图(Sprite)精准讲解

用户访问网站时,浏览器向服务器发送一系列请求。例如,网页上的每个图像都必须经过一次请求,才能最终显示给用户。但是网页包含很多图像资源(例如页面上显示的图片、网页上的背景图像、装饰性图像等),浏览器经常请求服务器,从而大大降低网页的加载速度。为了有效地减少服务器请求次数和加快页面加载速度,出现了CSS Sprites技术(也称为精灵技术。

简单来讲,精灵技术就是一种处理网页背景图像的方式,它需要将一个页面中涉及到的所有或一部分较小的背景图像合并到一张较大的图片中,然后再将这个图片应用到网页种。通常情况下,我们只是将背景图像中那些较小的、零碎的图像集中到一个大的图像中,这个较大的图像被称为精灵图(也被称为雪碧图),如下图所示就是淘宝网上应用的一个精灵图:

1512021630-0
图:淘宝网中的精灵图

精灵图的使用也非常简单,只需要借助 background 或者 background-position 属性来定位背景图像的位置即可。下面以上图所示的精灵图为例,来演示一下精灵图的使用:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. ul li {
  6. float: left;
  7. width: 30px;
  8. height: 30px;
  9. list-style: none;
  10. margin: 5px;
  11. border: 1px solid #CCC;
  12. border-radius: 6px;
  13. }
  14. ul li:nth-child(1){
  15. background: url(./sprite.png) no-repeat 4px 1px;
  16. }
  17. ul li:nth-child(2){
  18. background: url(./sprite.png) no-repeat -38px 1px;
  19. }
  20. ul li:nth-child(3){
  21. background: url(./sprite.png) no-repeat -81px 3px;
  22. }
  23. ul li:nth-child(4){
  24. background: url(./sprite.png) no-repeat -123px 2px;
  25. }
  26. ul li:nth-child(5){
  27. background: url(./sprite.png) no-repeat -171px 0px;
  28. }
  29. ul li:nth-child(6){
  30. background: url(./sprite.png) no-repeat -214px 2px;
  31. }
  32. ul li:nth-child(7){
  33. background: url(./sprite.png) no-repeat -267px 1px;
  34. }
  35. ul li:nth-child(8){
  36. background: url(./sprite.png) no-repeat 2px -36px;
  37. }
  38. </style>
  39. </head>
  40. <body>
  41. <ul>
  42. <li></li><li></li>
  43. <li></li><li></li>
  44. <li></li><li></li>
  45. <li></li><li></li>
  46. </ul>
  47. </body>
  48. </html>

运行结果如下:

1512025307-1
图:精灵图演示

简单来说,精灵图就是一个大的背景图,您只需要使用 background-position 来移动背景图,从而只显示背景图的一部分。目前为止,精灵图发展的已经非常成熟,阿里巴巴、百度、谷歌、京东、淘宝等大型网站中都可以看到精灵图的影子,使用精灵图可以减少图片的体积,也可以显著的减少对服务器的请求次数,提高网页的加载速度。当然,使用精灵图也不是没有弊端,比如:

  • 在图片合并的时候,需要把多张图片有序的、合理的合并成一张图片,每个小图之间需要预留足够的空间;
  • 在宽屏或者高分辨率的屏幕下来自适应页面宽度时,如果图片不够宽,会出现背景断裂;
  • 精灵图在维护的时候比较麻烦,如果页面背景有少许改动,就需要修改整个精灵图。
© 版权声明
THE END
喜欢就支持一下吧
点赞15 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片