博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【转】CSS 与 HTML5 响应式图片
阅读量:5989 次
发布时间:2019-06-20

本文共 3993 字,大约阅读时间需要 13 分钟。

关于响应式的,近来国内外也不断提到,还是目前比较流行的技术话题,这篇文章来至淘宝UED的,讲得是响应式图片,写得很不错。

 随着 Retina 屏幕的逐渐普及,网页中对图片的适配要求也越来越高。如何让图片在放大了两倍的 Retina 屏幕显示依然清晰,曾经一度困扰着网页开发者,好在 CSS3 与 HTML5 已经着力在改变这种现状。那么到底什么是响应式图片呢?

什么是响应式图片?

响应式图片是指:用户代理根据输出设备的分辨率不同加载不同类型的图片,不会造成带宽的浪费。同时,在改变输出设备类型或分辨率时,能及时加载对应类型的图片。

CSS3 响应式图片

对于很多 IOS 开发者来说可能已经不太陌生了,为了适配 Retina 屏幕,传统的 CSS3 实现方式是通过加载一张宽高分别放大两倍的图片,然后通过  使背景图片尺寸减小一倍「background-size:50% 50%;」,例如:

 
.mod .hd h3 {    background-image:url(http://img02.taobaocdn.com/tps/i2/T10s3JXn4XXXXnbIAn-105-160.png);/* 普通屏幕 */}/* ------------- Retina ------------- */@media only screen and (-o-min-device-pixel-ratio: 2/1), /* Opera */       only screen and (min--moz-device-pixel-ratio: 2), /* Firefox 16 之前 */       only screen and (-webkit-min-device-pixel-ratio: 2), /* Webkit */       only screen and (min-resolution: 240dpi), /* 标准 */       only screen and (min-resolution: 2dppx) /* 标准 */{.mod .hd h3{    background-image:url(http://img04.taobaocdn.com/tps/i4/T1947tXmJhXXcCfooh-210-320.png);    background-size: 105px 155px;}}

两张图片的对比效果:

在制作@2x图片时需要注意一些问题:

如果类似上图一样是纯文字内容的图片,不要直接从大图片缩放为小图片,这样文字效果会有些失真,这是 Photoshop 渲染的问题。应该调整字号,再重新排版。可以直接看看: 的效果。

蓝框内是直接缩放图片大小的效果,红框内是把字号从32号改成16号的效果。

 中用来定义设备分辨率的是  媒体特性,同时派生出两个媒体特性,分别是 「min-resolution」和 「max-resolution」。该规范中规定:若查询  (专业术语,指高度与宽度不等的像素,可以理解为「非正方形像素」。计算机屏幕上及中的像素是正方形的(像素宽高比为 1:1)。标准清晰度数码视频信号中的像素都不是正方形的。例如:NTSC制式的像素高度大于宽度,而PAL制式的像素宽度则大于高度。)设备,在「min-resolution」查询中指定的值必须与最稀疏尺寸进行比较,在「max-resolution」查询中必须与最密集尺寸进行比较。对于「resolution」(没有「min-」或「max-」前缀)从不查询  设备。另外在 CSS image Level 3「」属性中定义了一些,比如「dppx」,各浏览器支持情况如下:

 

特性 Chrome Firefox (Gecko) IE Opera Safari (WebKit)
基本特性 不支持「1」「4」 3.5 (1.9.1) 「2」 9 9.5 不支持 「1」「4」
dppx 「4」 16.0 未知 12.10 「4」

 

  • 「1」Chrome 支持私有属性「-webkit-min-device-pixel-ratio」和「-webkit-max-device-pixel-ratio」。
  • 「2」Firefox 8.0 之前错误的接受了整数数值(不带单位),16 开始支持 dppx 单位。
  • 「3」。
  • 「」在 Webkit 实现了 CSS3「」属性, 并且支持了 , 和  单位,具体 Chrome 哪个版本开始支持可以自行测试,相信   中很快也会支持了。

需要注意几点:

  1. 「-o-min-device-pixel-ratio」的取值是分数比如「2 /3」,,详见:
  2. Firefox 16 之前版本是「min–moz-device-pixel-ratio」,min 后面有两个「-」。
  3. 1dppx 相当于 96dpi。

显而易见,通过  来实现「响应式图片」还是很麻烦,CSS 代码的可维护性不高,有一些 hack 的味道。我们更期望一种原生的语法来选择不同的图片,值得庆幸的是  中就实现了这种原生语法的「」。

「image-set」语法:

 
= image-set( [
, ]* [
|
] )
= [
|
]

那么上面的例子我们可以改为:

 
background-image:url(http://img02.taobaocdn.com/tps/i2/T10s3JXn4XXXXnbIAn-105-160.png);/* 普通屏幕 */background-image: -webkit-image-set(    url(http://img02.taobaocdn.com/tps/i2/T10s3JXn4XXXXnbIAn-105-160.png) 1x,    url(http://img04.taobaocdn.com/tps/i4/T1947tXmJhXXcCfooh-210-320.png) 2x);/* Retina */

这里的单位「x」等同于「」,将来是否统一还有待进一步讨论。注意 Webkit 目前只实现了 url() 形式的取值,color、*-gradient() 等暂不支持,而且「x」取负值似乎也是合法的。

-webkit-min-device-pixel-ratio: 1.0

  • 所有非 Retina 的 Mac
  • 所有非 Retina 的 iOS 设备
  • Acer Iconia A500
  • Samsung Galaxy Tab 10.1
  • Samsung Galaxy S
  • 其他设备

-webkit-min-device-pixel-ratio: 1.3

  • Google Nexus 7

-webkit-min-device-pixel-ratio: 1.5

  • Google Nexus S
  • Samsung Galaxy S II
  • HTC Desire
  • HTC Incredible S
  • HTC Velocity
  • HTC Sensation

-webkit-min-device-pixel-ratio: 2.0

  • iPhone 4
  • iPhone 4S
  • iPhone 5
  • iPad (3rd generation)
  • iPad 4
  • 所有 Retina displays 的 Mac
  • Google Galaxy Nexus
  • Google Nexus 4
  • Google Nexus 10
  • Samsung Galaxy S III
  • Samsung Galaxy Note II
  • Sony Xperia S
  • HTC One X

HTML5 响应式图片

CSS「image-set」 解决了背景图片的响应式问题,但是 HTML中的 img 元素怎么办呢?正当我一筹莫展的时候,2011年11月  提出了HTML5 的一个解决草案:

 

于此同时,其他的一些想法如雨后春笋般涌现出来,于是W3C 社区讨论组 应运而生。最新的规范在这里:。截止本文发布时间,最近一次更新是 2013年1月7日,规范示例:

 

Accessible text

可以看到这里的「srcset」属性类似「image-set」,通常情况下,「srcset」里面的资源是具有 fallback 特性的,也就是说第一个图片资源无法加载的时候可以跳过加载后面的备用资源。

但是 Apple 的  提出的方案是这样的:

 
decent alt text for foo.

诚然,任何一个新标准的提出,都会存在各种不同的声音,这是好事,作为网页的最终开发者其实并不太关心实现语法。有任何问题大家也可以直接到 参与讨论。

小结

本来想把新年的第一篇文章写的欢乐一些,不过貌似没啥槽点。HTML5 响应式图片的草案还刚刚开始,但是前景还是很美好的。目前我们能做的就是在CSS 中使用「image-set」属性值,因为目前大部分 Retina 屏幕的设备的浏览器都是基于 Webkit 内核的,如果有特殊的需求可以使用 Media Queries。

非常感谢 kenny 对本文排版细节提出的 14 条建议,本文排版遵循:

  • 使用繁体中文引号 「」代替简体中文「“”」引号;
  • 中英文混排时英文首尾各加一个空格。

原文地址:

作者:白树

出处:

转载地址:http://onilx.baihongyu.com/

你可能感兴趣的文章
Android 事件分发机制
查看>>
webp使用总结
查看>>
【Code-Snippet】Video播放
查看>>
前端栈和堆浅析
查看>>
理解Cookie和Session
查看>>
Jqury 进阶增强
查看>>
【FAQ】加密保护软件 WinLicense 注册常见问题解答(六)
查看>>
GGally与pairs相关关系图_史上最全(二)
查看>>
[北京望京] 掘金招聘技术编辑
查看>>
70行代码写的组合链式调用的通用多类型视图RecycleViewAdapter
查看>>
TCP
查看>>
JS学习--JSON对象
查看>>
win系统下nodejs安装及环境配置
查看>>
Python基础语法(一)
查看>>
Android 把性能优化落到实处
查看>>
月薪2万的程序员和年薪4万的事业编,你选哪一个?
查看>>
区块链科普之第一个去中心化交易平台
查看>>
说说javascrpt的重构
查看>>
用纯 DOM 的方式结合 Puppeteer 自动生成网页骨架屏
查看>>
我学react之父子组件通信
查看>>