关于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,否则点击元素的时候,会出现超长的虚线框。
相关推荐
Ladyseven 2020-10-22
李鴻耀 2020-08-17
yaodilu 2020-08-03
qiupu 2020-11-04
多读书读好书 2020-11-03
RedCode 2020-10-28
jiedinghui 2020-10-25
hellowzm 2020-10-12
zuncle 2020-09-28
Ladyseven 2020-09-11
jiedinghui 2020-09-07
xiaohuli 2020-09-02
葉無聞 2020-09-01
impress 2020-08-26
ThikHome 2020-08-24
nicepainkiller 2020-08-20