【前言】

做开发的小伙伴可能经常遇到雪碧图,那么究竟什么是雪碧图呢?

【简介】

官方解释

CSS雪碧图即CSS Sprite(精灵),在国内很多人叫css精灵,是一种网页图片应用处理方式。它允许你将一个页面涉及到的所有零星图片都包含到一张大图中去,这样一来,当访问该页面时,载入的图片就不会像以前那样一幅一幅地慢慢显示出来了。对于当前网络流行的速度而言,不高于200KB的单张图片的所需载入时间基本是差不多的,所以无需顾忌这个问题

简单理解

所谓的雪碧图是一种CSS图像合并技术,该方法是将小图标和背景图像合并到一张图片上,然后利用css的背景定位来显示需要显示的图片部分;简单说就是在一整张图片中分割出自己想要的部分,也可理解为图片截取显示(坐标的移动)

【由来】

加速的关键,不是降低质量,而是减少个数。传统切图讲究精细,图片规格越小越好,重量越小越好,其实规格大小无所谓,计算机统一都按byte计算。客户端每显示一张图片都会向服务器发送请求。所以,图片越多请求次数越多,造成延迟的可能性也就越大

【原理】

简单理解:原理就是把你的网站上用到的一些图片整合到一张单独的图片中,从而减少你的网站的HTTP请求数量。该图片使用CSS background和background-position属性渲染,这也就意味着你的标签变得更加复杂了,图片是在CSS中定义,而非<img>标签

【优点】

减少加载网页图片时对服务器的请求次数;

可以合并多数背景图片和小图标,方便在任何位置使用,这样不同位置的请求只需要调用一个图片,从而减少对服务器的请求次数,降低服务器压力,同时提高了页面的加载速度,节约服务器的流量。

②提高页面的加载速度

sprite技术的其中一个好处是图片的加载时间(在有许多sprite时,单张图片的加载时间)。由所需图片拼成的一张 GIF 图片的尺寸会明显小于所有图片拼合前的大小。单张的 GIF 只有相关的一个色表,而单独分割的每一张 GIF 都有自己的一个色表,这就增加了总体的大小。因此,单独的一张 JPEG 或者 PNG sprite 在大小上非常可能比把一张图分成多张得来的图片总尺寸小。

【缺点】

①在图片合并的时候,你要把多张图片有序的合理的合并成一张图片,还要留好足够的空间,防止板块内出现不必要的背景;这些还好,最痛苦的是在宽屏,高分辨率的屏幕下的自适应页面,你的图片如果不够宽,很容易出现背景断裂;

②CSS Sprites在维护的时候比较麻烦,如果页面背景有少许改动,一般就要改这张合并的图片,无需改的地方最好不要动,这样避免改动更多的css,如果在原来的地方放不下,又只能(最好)往下加图片,这样图片的字节就增加了,还要改动css

(2)为什么使用雪碧图时background-position属性值为负数?

上面的例子已经阐述了如何使用雪碧图,只不过初学者可能会对雪碧图中的background-position属性值为负值有所疑惑。这个问题其实不难回答,如果细心的人应该很早就发现了使用负数的根源所在。这边用上面的Demo为例,来分析这个问题。上面的span标签是一个25px长宽的容器,在使用背景图时,背景图的初始位置会从容器的左上角的开始铺满整个容器,然而容器的大小限制了背景图呈现的大小,超出容器部分被隐藏起来。假如设置background-position: 0 0 那么意味着,背景图相对于容器(span标签)x轴=0;y轴=0的位置作为背景图的起始位置来显示图片。所以如果需要在容器中显示第二个图标,意味着雪碧图x轴方向要左移动,左移动雪碧图即它的值会设置为负数,同理y轴方向也一样。

【总结】

CSS Sprites非常值得学习和应用,特别是页面有一堆icon(图标)。总之很多时候大家要权衡一下利弊,再决定是不是应用CSS Sprites

css雪碧图及优缺点相关推荐

  1. CSS 雪碧图及其优缺点

    CSS Sprites简介:国内叫雪碧图或者雪碧精灵.它允许将网页中多个零星小图都包含到一张大图中去,减少每个图的 HTTP 请求来提高图片加载效率,通过 background-image.backg ...

  2. CSS雪碧图demo(含雪碧代码)

    css雪碧图demo效果图,含hover,代码附件下载sprite_demo.zip 雪碧图制作问题参考: HTML 5开发的在线雪碧图片合成工具 http://developer.51cto.com ...

  3. iconfont与雪碧图的优缺点

    iconfont(图标字体) 可以缩放的矢量图标.你可以使用CSS对它们进行修改:大小,颜色,阴影等.体积特别的小.可能几百个图标才几十KB. 优点: 高清保真,因为是SVG图形 灵活性,可以设置大小 ...

  4. CSS雪碧图制作emoji表情包

    效果图: 原理:利用雪碧图,来实现emoji表情包,减少图片请求数. 表情包转换为文字 & 文字转换为表情包 维护两个对象来实现. 缺点:表情包大小由雪碧图中表情包大小控制,不能更改. htm ...

  5. css雪碧图如何调整大小

    1.通过transform: scale(0.5);来缩放,但在本身有过渡或动画时,刷新页面会有卡顿拉伸现象!不建议这样做! 2.直接调整雪碧图background-size大小 例如,雪碧图规格14 ...

  6. html css雪碧图,css常见小技巧(雪碧图)

    1.CSS Sprite(雪碧图|精灵图)指什么? 有什么作用 CSS雪碧 即CSS Sprite,也有人叫它CSS精灵,是一种CSS图像合并技术,该方法是将小图标和背景图像合并到一张图片上,然后利用 ...

  7. html css雪碧图,css sprite css雪碧图生成工具

    什么是css sprite CSS sprite在国内很多人叫css精灵,是一种网页图片应用处理方式.它允许你将一个页面涉及到的所有零星图片都包含到一张大图中去,这样一来,当访问该页面时,载入的图片就 ...

  8. css雪碧图动画,CSS3动画——雪碧图的实现

    前言 作为一个前端的初学者,现在好像已经在nodejs上越跑越偏,之前一直崇拜的CSS3和HTML5动画,如今也好久没有管.因为之前学了好多知识点,但是没有系统的进行总结,就从这篇文章开始,对一些碎片 ...

  9. css 雪碧图计算方式,前端必备 CSS Sprites雪碧图生成工具

    [摘要] CSS Sprites又称css精灵或者谐音css雪碧,是一种网页图片应用处理方式,今天为大家分享一个一键生成css雪碧图片的工具,复杂的事情简单化,提高开发效率. CSS Sprites又 ...

最新文章

  1. FPGA 内部双口块RAM 读写实现
  2. 利用被入侵的路由器迈入内网——抓包,利用路由器漏洞入侵,进行流量劫持...
  3. JQuery官方学习资料(译):$( document ).ready()
  4. 将下图的nfa确定化为dfa_作业8 非确定的自动机NFA确定化为DFA
  5. 优雅还不够,简洁才高效!——用NValidator一句话搞定客户端检测
  6. 对数学本质特征的若干认识
  7. Service Fabric 用 Powershell 部署应用到本地
  8. 鸿蒙初开踏青时主要内容,鸿蒙初开踏青时
  9. 人员梯度培养_人员管理 | 生产班组员工队伍管理及制度建立
  10. Python 进阶 —— x = x+1 vs x += 1
  11. linux网络客户端命令
  12. 容器操作系统再添丁,AWS开源Bottlerocket,类似RancherOS?
  13. oracle em 证书错误,导航阻止
  14. github用户followers分析
  15. 计算机科学全奖博士招生,福特汉姆大学魏文启课题组
  16. 技术美术知识学习5200:光追相关概念介绍
  17. 友盟+全面解析ios 卡顿问题
  18. 编程比赛项目和时间汇总
  19. 技术人员应该具备的几项基本技能
  20. python给图片加半透明水印_图片添加半透明文字水印 Python

热门文章

  1. 操作分区表对global和local索引的影响
  2. 拼图工具箱微信小程序源码下载支持多种拼图模式制作
  3. SpringBoot整合TkMybatis(通用mapper)
  4. Error processing condition on org.springframework.boot.autoconfigure.context.PropertyPlaceholderAuto
  5. 架构师成长记_第八周_04_ES-head 与 postman基于索引的基本操作
  6. 英文短语缩写问题 1199 getline()使用
  7. 银行存钱利率最大化问题C语言
  8. 动手做个VR眼镜,找回童年的感觉
  9. 【PTA】7-14 福到了
  10. 2022-03-02每日刷题打卡