关于css sprite 概述

     记得当时面试的时候被问到对css sprite的认识,现在详细的解析一下,这个用法,加深一下映像,总没啥坏处。

     一、什么是css sprite?用css sprite有什么好处?

      css sprite,也有人叫css精灵、css雪碧,说的通俗一点儿,就是将css中定义的多个背景图片合成到一张,以减少http请求数。目前很多网站都在使用,算不上新技术,但是也很好用。

       最大的优点就是可以减少http的请求数,一般情况下,合成后得到的图片,比单张图片相加后所得的数据量,要小得多。另一个喜爱大型 sprite 的理由是可以利用一些 sprite 生成器来简单得生成 sprite。

      二、经典的例子——社交网站分享功能

<ul class="share"> 
 <li>分享到:</li> 
 <li><a class="renren" href="#" title="分享到人人网">人人网</a></li> 
 <li><a class="kaixin"  href="#"  title="分享到开心网">开心网</a></li> 
 <li><a class="sina"  href="#"  title="转帖到新浪微博">新浪微博</a></li> 
 <li><a class="douban"  href="#" title="分享到豆瓣">豆瓣</a></li> 
 <li><a class="more"  href="#"  title="添加到更多">更多</a></li> 
 </ul>
ul.share li{float:left;}
 ul.share li a{display:block;width:25px;height:25px;text-indent:-9999px;}
 a.renren{background:url(../images/share.gif) 0 0 no-repeat;}
 a.kaixin{background:url(../images/share.gif) -25px 0 no-repeat;}
 a.sina{background:url(../images/share.gif) -50px 0 no-repeat;}
 a.douban{background:url(../images/share.gif) -75px 0 no-repeat;}
 a.more{background:url(../images/share.gif) -100px 0 no-repeat;}
    分享功能是css精灵最常用的一种展示形式,不过上边的代码也有不完全的地方,css代码应该使用background-position这样可以增强代码的可维护性。此外图像替换时,如果使用text-indent属性之后,如果用户禁用图片,那么相对应的文字链接也就看不到了。在firefox下还需要为元素设置overflow:hidden,否则点击元素的时候,会出现超长的虚线框。

相关推荐