更加智能好用的倍图展开方式

背景

昨天突然i想起来前两年尝试过的img-srcset这个属性,当时赶着完成课程设计,在firebox发现有效果,在chrome上半点用都没,但是这玩意的兼容性如下:

imgset兼容性

其实兼容性我觉得挺好的,所以我还是要再尝试尝试!

介绍

srcsert具有两个版本:

  1. 旧版
![](mm@1x.jpg)
  1. 新版
<img src="./img/x-pc.png"
        srcset="./img/x-pc.png 300w, ./img/x-pc@2x.png 500w"
        sizes="(min-width: 300px) 400px, calc(100vw - 2rem)">

emm.....旧版不想说了,反正不好用也已经被淘汰了,新版的,其实很简单:

  1. srcset这个属性定义图片然后告诉浏览器你图片的宽度
  2. sizes这个属性定义在不同情况下,对于图片宽度的定义,单位除了不能使用%(很费解,不过可以用vw代替),calc()也可以

看一看

  • 宽度250px情况下
250px
  • 宽度300px情况下
300px

懒得录gif,当你宽度慢慢增大一个临界点时浏览器会去加载二倍图并且替换,sizes规定了图片的大小,比如第一个例子上图片大小恒定500px,注意sizes的合理设置,否则会产生图片大小的跳动,得到两个结论:

  1. 优先适配高质量图片原则
  2. 存在缓存时优先加载缓存图片

进阶

我们来探究一下w这个单位,先从sizes这个属性说起。
sizes相当于动态定义图片的widthheight,然后我们把上面的例子做一些修改:

<img src="./img/x-pc.png"
        srcset="./img/x-pc.png 150w, ./img/x-pc@2x.png 250w"
        sizes="(min-width: 200px) 400px, calc(100vw - 20px)">
150px
171px

图1: 2 * (150px - 20px)
图2: 2 * (171px - 20px)
我个人的理解是:w只是告诉浏览器,我认为这张图是什么大小,浏览器会根据你给的值取计算出一个比值,比如上面这个比值是2,然后去乘下面的sizes,公式就是:
实际渲染大小 = (原图大小 / 声明大小) * 对应的sizes

为什么这么做呢?

我猜测,如果按w等于图片宽度的话,在高质量的图片下并不合适,所以w只是起到一个描述图片尺寸作用,就和你爸妈一样,我觉得XXXXXX。

结论

我瞎写,你随便看看就好,觉得哪里不对可以留言

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,844评论 1 92
  • 原文“响应式(Responsive)”这个词我想大家没有听过一千遍,也有一百遍了。响应式是指实现不同屏幕分辨率的终...
    Www刘阅读 723评论 0 0
  • 1.块级元素和行内元素 块级(block-level)元素;行内(内联、inline-level)元素。 块元素的...
    饥人谷_小侯阅读 2,067评论 1 4
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,350评论 0 11
  • AMD 和 CMD 的区别有哪些?AMD 是 RequireJS 在推广过程中对模块定义的规范化产出。CMD 是 ...
    竿牍阅读 728评论 0 1