1

我有两张图片:一张桌面版,一张移动版。当视口宽度调整到 480 像素以下时,我希望桌面图像被移动图像替换,就像下面的带有 background-image 属性的 CSS 一样:

.logo { background-image: url(http://placehold.it/400x200&text=desktop); }
media screen and (max-width: 480px) {
    .logo { background-image: url(http://placehold.it/300x150&text=mobile); }
}

我想我可以使用 srcset HTML 属性来实现这一点:

<img src="http://placehold.it/400x200&amp;text=desktop" alt="" srcset="http://placehold.it/300x150&amp;text=mobile 480w">

但它不起作用,浏览器一直显示移动图像并在视口调整大小时重新缩放它,但我希望这两个图像保持各自的原始大小。

是否可以使用 srcset 实现此行为?

4

1 回答 1

2

听起来您想做“艺术指导”,即图像的不同不仅仅是较大图像的较小缩小版本。如果是这样,您需要使用该picture元素。

<picture>
 <source srcset="http://placehold.it/300x150&amp;text=mobile"
         media="(max-width: 480px)">
 <img src="http://placehold.it/400x200&amp;text=desktop" alt="...">
</picture>

但是,如果您的小图像实际上是大图像的缩小版本,那么您可以使用srcset,但是您无法控制选择哪个图像。由浏览器根据屏幕密度、网络状况、用户偏好、浏览器缓存等选择最佳的。

<img src="http://placehold.it/400x200&amp;text=desktop"
     srcset="http://placehold.it/400x200&amp;text=desktop 400w,
             http://placehold.it/300x150&amp;text=mobile 300w"
     sizes="(max-width: 480px) 300px, 400px">

注意:如果srcset使用 并且较大的候选图像在缓存中,Chrome 将始终显示此缓存的候选图像 - 无论实际视口大小如何。

于 2015-04-07T15:13:17.957 回答