图片优化的最佳实践

如今行业内的图片格式越来越丰富,优化、压缩的方法也越来越多。我们该如何选择适合自己项目的图片优化方法呢?让我们来一起探讨图片优化的最佳实践吧。

我选择了几种常用的图片格式和优化方法来做实验,我会分别从【矢量图】和【位图】来进行分析。

一、矢量图 -- iconfont

什么是iconfont?
从字面意思理解就是“图标字体”。

iconfont

为什么用iconfont?
1. 自由变换大小和颜色等样式
2. 画质清晰
3. 易于维护
4. 兼容性好
css能为字体加的样式对于图标字体都可适用。

如何使用iconfont?
这里我浓缩成了3步:

1. 在网上选择一款你喜欢的图标字体生产工具,将svg图片提交上去;

第一步

2. 下载包含字体文件、样式文件、Demo的文件包;

第二步

3. 使用代码,利用demo中的代码修改成适合你用的。

第三步

二、矢量图 -- svg

什么是iconfont?
谷歌和度娘上都有一大段专业的文字来描述,我的简单理解就是一种二维矢量图片格式。

为什么用svg?
使用方便
任意缩放
文件体积小

如何使用svg?
我分为2步:

1.导出 -- 用任何一款可以画矢量图的软件都可以导出svg格式图片,如:Adobe Illustrator/Sketch

Sketch


AI

这里可以注意的是,图形勾勒过程中可以去掉多余的锚点,锚点越少文件越小。

2. 应用 -- 导出的图片应用在网页中就像通常用jpg/png格式的图片一样引入相应的图片路径就行。

svg应用

svg既然有这么多优点,又方便使用,我们来看看效果如何呢?下面分别用svg图和png图做一个简单的对比:

效果对比

我们发现在质量几乎相同的情况下svg图片体积小很多,但别忘了svg是矢量图形,其实质量会比位图png好很多。如此美妙的图片格式我们还有什么理由拒绝使用它。

查理·芒格说:只有了解一个知识的局限性,才能真正拥有一个知识。

接下来我们看看svg的兼容性:

svg兼容性

兼容性看似前景一片大好,但还是有些低版本浏览器无法支持。没关系,我们先把问题暂时放一放。后面再来聊一聊兼容性的解决方案。

三、 位图

关于位图我通过一系列实验,得出了两条结论:
- 图片颜色越丰富webp的压缩效果越好
- 颜色单一的图片压缩模式png优于webp优于jpg

为了方便理解我画了个简单的图表来描述png、jpg、webp与文件大小、图片颜色丰富程度的关系。

我是如何得出这个结论的呢?我在几百张图片实验中挑选了三组典型的案例来展示:

这组图片说明了图片颜色越单一png格式的压缩效果越好。

数据对比1


这组图片虽然看上去貌似颜色单一,但它标题的阴影所用的灰色通道占据了大量的颜色数,所以可以看出其webp的表现较优越。

数据对比2


这张颜色相对丰富的图片就更加能说明webp对于颜色数多的图片优异的表现能力了。

数据对比3

四、位图 -- webp

说了这么多webp到底是什么呢?
谷歌作为其开发商用了一大段文字来描述,我简单的理解webp就是一种压缩效果更好的图片格式。

为什么用webp?
体积更小
颜色丰富

如何使用webp?
关于如何使用webp我在线上找了一些转换压缩工具和软件,使用后发现这些工具的参数、稳定性都不太一样,就导致导出的图片效果也不太一样,非常影响我实验的最终效果。对比各种方案后还是选择工程化的方式比较靠谱。

五、gulp插件自动压缩

为什么选择工程化?
自动化 — 节约人力
标准化 — 避免出错

如何使用?
这里我选择了以下几种gulp插件供大家参考:

gulp插件

gulp插件的用法:

imagemin


webp

从上面的截图可以看出imagemin和webp插件除了可配置需要压缩的图片格式外,还可以自行配置压缩的质量。我想重点说明一下压缩质量可以根据自己的项目需要来配置参数,截图中是我根据实验中的图片总体输出质量和体积不断测试出的一个相对较合适的参数。

我分别做了三个方案的测试,测试对象是一个有124个图片文件的文件夹,结论如下:

从统计结果来看方案2(将大部分图片压缩转换成webp格式)的效果是压缩率最高的,虽然耗时相对较长,但比起人工手动在线压缩优势会大很多。

以下是方案2的实验截图:

实验截图

实验得出的结论是从整体来看webp的压缩格式相比png和jpg都相对较优。

webp既然如此好用,我们来看看兼容性。

webp兼容性

这样看来我们接下来要考虑兼容图片格式相关工作了。

六、按需加载

关于兼容浏览器不支持webp的方案我简单的为大家介绍3种:

1. h5标签

这个方案最简单,利用<picture><source>标签,具体实现方式如下截图:

当浏览器支持source标签srcset属性里的图片时会显示此图片,如果不支持则会向下兼容img标签里的图片,所以img标签里通常放入是浏览器都支持的普通图片格式。

但貌似兼容性并不是那么理想android又不支持新h5标签,欲哭无泪有木有?我还是决定再测试一下。

网上有资料说source标签也可以用src属性,于是我做了几组测试,测试结果如下图:

能展示微证券banner图的是android系统,能看到小黄人说明浏览器不支持webp图片格式,那第二张图是怎么回事?

我们通过下面这个表格来分析一下关于source标签里srcset这个属性。

通过测试得出以上表格结论,说明source标签是不支持“src”属性的。但是如果srcset里的路径图片是webp格式的话苹果相关的产品都是不支持,而且还不向下兼容,不显示任何图片。以此判断如果srcset里是webp格式,由于浏览器本身是支持srcset的所以当它遇见的是不支持的webp格式就没有再向下兼容。
于是我将srcset改为src,浏览器不支持src的属性,直接就向下兼容了。所以测试图片中的第二张图片下面展示的小黄人是因为source标签内用src属性,浏览器支持向下兼容了png格式的小黄人图片。

2. JS兼容方案

此段代码先判断浏览器是否支持webp图片格式,原理是先加载一张webp图片格式。如果浏览器能加载到图片的宽高说明是支持的,反之则不支持。

接下来就可以利用这段代码设置函数用来判断支持或不支持webp格式时的操作。

在html中设置参数分别用来插入支持或不支持webp格式时的图片路径。

3. 服务器端兼容方案

利用服务器端请求浏览器端的accept 头,支持webp图片格式的就返回webp格式的文件。这些配置可以用nodejs实现,也可以在nginx中完成。

七、动图--apng

既然我们有很多方案可以向下兼容图片,再介绍一个好用的动图格式——apng。

什么是apng?
简单说就是一种png扩展的动态图片格式(Animated png)。

为什么用apng?
支持24位彩色图像,表现更多动态图片细节
支持8位透明通道,背景完全透明

怎么用?
为大家介绍一种在线生成的工具,可以把每一帧图片倒入利用它生成apng格式的动图

https://ezgif.com/apng-maker

效果对比
我在网上找到一张图非常能说明gif、png、apng三者的关系。大家一看便知了。

apng兼容性

虽然兼容性看上去不是特别理想,但是apng自己会向下兼容,若是在不支持的浏览器上apng会只显示第一帧,那么图片看上去会像png图。

不支持apng时:

支持apng时:

八、最佳实践总结

综上所述那么多图片优化的格式和方法,我将它们和相应的情况做了个小结:

随着技术的进步会有越来越多的技术和方法来完善图片优化的工作,面对技术的进步,我们应该用辩证的方法看待问题。遇到困难敢于开拓,勇于实践,通过不断地探索和验证使我们更加接近真理。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容

  • 移动端图片格式调研 图片通常是移动端流量耗费最多的部分,并且占据着重要的视觉空间。合理的图片格式选用和优化可以为你...
    AngeloD阅读 1,235评论 0 5
  • 注明:本人原创翻译,原版为Essential Image Optimization电子书,这里将其拆分为几篇文章发...
    ProteanBear阅读 5,116评论 0 5
  • 本文会不定期更新,推荐watch下项目。如果喜欢请star,如果觉得有纰漏请提交issue,如果你有更好的点子可以...
    天之界线2010阅读 18,200评论 19 153
  • 图片通常是移动端流量耗费最多的部分,并且占据着重要的视觉空间。合理的图片格式选用和优化可以为你节省带宽、提升视觉效...
    傻傻小萝卜阅读 745评论 1 9
  • 前言 在互联网快速发展,热火朝天的当下,无论是PC端,还是移动端,图片都是必不可少的元素。好的图片能让我们的应用熠...
    无神阅读 482评论 0 0