本文主要内容简译自Dava Shea的英文文章 CSS Sprites: Image Slicing’s Kiss of Death如果觉得博主讲的含糊不清的话,可以看作者原文。

熟悉了常规切图的我们,在浏览大型网站的时候,有时会忍不住审查元素一下,就会发现他们会把所有的小图标整合在一个图片上,比如谷歌的

而且如果你细心一点,你会发现Google的二级搜索结果页面是底下的分页的那一排o也是用CSS Sprite做的。那么什么是CSS Sprite呢?

CSS Sprites是目前大型网站的图片处理的一种方式,原理主要是将网站上的小图片或者图标整合在一张大图上,在用css的background-position属性通过x/y轴的位置来定位图片,从而减少服务器对图片的请求数目,提高网站的加载速度。当然如果你不做大型网站,不需要精细到加载速度的时候,CSS Sprites也会制作和维护带来一些不必要的麻烦。但是当你掌握其用法时,利用CSS Sprites是可以和轻松的做出一些有趣的特效。

CSS Sprites是如何作用的?

     我们用到的工具无非就是css,运用我们的想法写出富有创造力的css。

然我们从原图本身说起,把矩形分为四个部分,我们可以看出来上半部分图片,是链接刚开始的效果,下半部分是我们把鼠标悬停在链接上的效果,我们把鼠标悬停在哪个部分哪个部分就会变色。

HTML代码如下:

<ul id="skyline">
<li id="panel1b"><a href="#1"></a></li>
<li id="panel2b"><a href="#2"></a></li>
<li id="panel3b"><a href="#3"></a></li>
<li id="panel4b"><a href="#4"></a></li>
</ul>

我们用四个<li>标签和<a>组成了四个不同部分的链接。

应用css

  

          #skyline{
width: 400px;
background-image: url(img/test-3.jpg);
height: 200px;
position: relative;
margin: 10px auto;
padding: 0;
}
#skyline li{
margin: 0;
padding: 0;
list-style-type: none;
position: absolute;
top: 0; }
#skyline li,#skyline a{
height: 200px;
display: block;
}

  注意我们并没有把图片放在链接里而是放在的ul里,一会儿你将看到原因。

我们将a元素设定空白透明但是有限定大小的block用来出发链接活动,通过定位包含它的li元素来定位,如果这里我们直接来定位a元素而不是定位li元素将在老版本的浏览器中出现错误。

定位链接

      li元素被绝对定位了(position:abosulute),那么为什么li元素没有出现在浏览器的窗口的上方,被定位的元素有一个怪异却很有用的特性,被绝对定位的后代元素不是相对于浏览器窗口定位,而是相对离它最近的并且position属性为relative的父元素进行定位。所以这里的li元素相对于#skyline进行定位。

  #panel1b {left:; width: 95px;}
#panel2b {left: 96px; width: 75px;}
#panel3b {left: 172px; width: 110px;}
#panel4b {left: 283px; width: 117px;}

所以通过如上代码我们就将每个li元素分别布局到四个小矩形的位置上,这是我们有了带有链接的图片地图,我们来看一下没有加上:hover时的效果和每个部分加border的效果

hover效果

       接下来我们将通过:hover使隐藏的下半部分图片剪裁一部分的方式显现,那么我们将移动图片使它精确定位呢,接下来就是CSS Sptites了,我们要讲的。

  #panel1b a:hover {
background: transparent url(test-3.jpg)
0 -200px no-repeat;}
#panel2b a:hover {
background: transparent url(test-3.jpg)
-96px -200px no-repeat;}
#panel3b a:hover {
background: transparent url(test-3.jpg)
-172px -200px no-repeat;}
#panel4b a:hover {
background: transparent url(test-3.jpg)
-283px -200px no-repeat;}

我们从那里获得的像素值呢,让我们把它拆分一下,第一个数值当然水平方向的值(距离左边),第二个值时垂直方向。垂直方向的数值都是相等的200px,因为图片的高度时400px的,上下半部分各占200px,下边的部分需要向上移动200px才能覆盖上半部分,还有一点就是一般background-position值都是负值,因为背景图都是定位在左上方的。

水平方向的偏移量则是li的宽度,第二个链接的偏移量则是前两个li元素宽度的和,以此类推。

这里是效果

Buttons效果和特殊形状

    通过以上的方式我们就可以在把网页上的按钮button应用各种效果,比如原图,我们可以做成这样的样式,方法同上

   但是我们遇到不规则图形时,这是可能会出现重叠现象(看效果),这是我们可以在原图上做做文章,拆分为两个hover后的效果图,如图,这是我们正确完整的效果

最新文章

  1. JS将秒转换为 天-时-分-秒
  2. java线程学习
  3. 网页特效:用CSS3制作3D图片立方体旋转特效
  4. mmzb游戏事故分析
  5. python设计模式1:创建型模式
  6. MySQL日志恢复误删记录
  7. Bzoj1150 数据备份Backup
  8. C#操作txt问件,进行清空添加操作
  9. 某种数列问题 (jx.cpp/c/pas) 1000MS 256MB
  10. jsp常用指令
  11. 飞信免费发送接口API的测试 httpClient
  12. 高质量程序设计指南C/C++语言——C++/C程序设计入门(4)
  13. CSS3秘笈:第六章
  14. WINDOWS XP中用命令行管理用户 net user命令
  15. 学习pthreads,使用互斥量进行同步
  16. Python中数学函数
  17. docker 私有 repository
  18. 根文件系统之init
  19. SQL小结
  20. Async和await关键字的用法

热门文章

  1. 【BZOJ3172】[Tjoi2013]单词 AC自动机
  2. CI框架之HOOKS使用流程及原理
  3. 基础3.Jquery操作Dom
  4. JS二维数组排序组合
  5. goEasy消息推送,pushlet 向特写用户实时推送
  6. Android事件分发小结
  7. android之Handler机制
  8. ios 关于问题 no matching provisioning profiles found
  9. CQOI 2016 不同的最小割
  10. 整理一自己不怎么熟悉的HTML标签(会陆续更新)