WebP,淘宝都在用的图片优化方法

WebP 是什么?
WebP 是一种同时提供了有损压缩与无损压缩的图片文件格式。可以大大压缩图片的大小,并且图片的质量和 png、jpeg 等相同。WebP 的无损压缩比 png 格式的文件平均少了 45% 的大小。

这里是使用了同一张图片转换为不同格式的图片后,对图片的大小进行对比的测试结果:

格式 webp jpeg png gif
大小 1.65MB 2.24MB 7.51MB 4.64MB
使用 webp 压缩后图片大小减少百分比 ↓ 26% ↓ 78% ↓ 64%
兼容性
目前大约 95.77% 的浏览器都支持 WebP 格式的图片,其中 Safari 浏览器仅在 Big Sur 及以上的macOS 系统才支持 WebP;针对不兼容的情况下,我们需要进行相应的降级措施。

在这里插入图片描述

降级处理原则

判断浏览器是否支持 webp 格式的图片
支持,展示 webp 格式的图片
不支持,使用图片原始格式进行展示
降级处理方式

JS 处理

   /** 
   * 判断浏览器是否支持 webp
   */
   // 方法1: 通过尝试加载一张 webp 格式的图片来判断
   function isSupportWebp() {
       const imgUrl = 'https://img.alicdn.com/imgextra/i2/O1CN01uvFm6B1XMMrTkObKV_!!6000000002909-0-tps-520-280.jpg_q75_.webp';
       const image = new Image();
       image.src = imgUrl;
       image.onload = function() {
           // 加载成功,说明支持 webp
           return true;
       }
       image.onerror = function() {
           // 加载失败,说明不支持 webp
           return false;
       }
   }

   // 方法2: 通过判断 HTMLCanvasElement.toDataURL() 返回的 dataURI 来判断
   function isSupportWebp() {
       const str = document.createElement('canvas').toDataURL('image/webp');
       // 如果支持则会返回传入的类型 image/webp --> 
       // 如果不支持则会返回默认值 image/png --> 
       return str.indexOf('image/webp') > -1;
   }

   /** 
   * 选择浏览器支持的图片格式
   */
   function getImg(compressedImg, originalImg) {
       const isSupport = isSupportWeb();
       return isSupport ? compressedImg : originalImg;
   }

复制代码


HTML 处理:`<picture>` 元素

  利用浏览器会选择 `<picture>` 元素中最匹配的子 `<source>` 元素,如果没有匹配的,就选择 `<img>` 元素的 src 属性中的 URL 这一特点。如果浏览器支持 image/webp 类型的图片,则加载 `<source>` 元素中 srcset 属性指向的资源,如果不支持则跳过 `<source>` 元素,加载 `<img>` 元素。

复制代码 ```

降级处理示例

拿淘宝首页举个例子

图片 URL:img.alicdn.com/imgextra/i2…

在这里插入图片描述

在 chrome 中加载的是 webp 格式的图片:

在这里插入图片描述

在 IE 中加载的则是 jpg 格式的图片:

在这里插入图片描述

可以看出淘宝是对图片的 URL 进行了特殊处理,通过在原始图片后加上 _.webp 后缀来做降级处理,如果当前浏览器支持 webp 格式的图片,则加载 webp 格式的图片,若不支持则去掉 _.webp 的后缀加载 jpg 格式的图片。

最后
如果你觉得此文对你有一丁点帮助,点个赞。或者可以加入我的开发交流群:1025263163相互学习,我们会有专业的技术答疑解惑

如果你觉得这篇文章对你有点用的话,麻烦请给我们的开源项目点点star: https://gitee.com/ZhongBangKeJi/CRMEB不胜感激 !

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值