分享好友 资讯首页 资讯分类 切换频道

分享一个非常有用的响应式图片案例html5+css3

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

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

 

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

  1. .mod .hd h3 { background-image:url(http://img02.taobaocdn.com/tps/i2/T10s3JXn4XXXXnbIAn-105-160.png );
  2.  
  3. @media only screen and (-o-min-device-pixel-ratio: 2/1),
  4. only screen and (min--moz-device-pixel-ratio: 2),
  5. only screen and (-webkit-min-device-pixel-ratio: 2),
  6. only screen and (min-resolution: 240dpi),
  7. only screen and (min-resolution: 2dppx)
  8. {
  9. .mod .hd h3{
  10. background-image:url(http://img02.taobaocdn.com/tps/i2/T1t9wzXlxXXXczY8cm-212-310.png);
  11. background-size: 106px 155px;
  12. }
  13. }

两张图片的对比效果:

1.pngT1947tXmJhXXcCfooh-210-320.png

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

T1lh31XbRXXXcwzecG-646-275.png

蓝框内是直接缩放图片大小的效果,红框内是把字号从32号改成16号的效果。CSS3 Media Queries 中用来定义设备分辨率的是「resolution」媒体特性,同时派生出两个媒体特性,分别是 「min-resolution」和 「max-resolution」。该规范中规定:若查询Non-Square Pixels (专业术语,指高度与宽度不等的像素,可以理解为「非正方形像素」。计算机屏幕上及高清晰度视频信号中的像素是正方形的(像素宽高比为 1:1)。标准清晰度数码视频信号中的像素都不是正方形的。例如:NTSC制式的像素高度大于宽度,而PAL制式的像素宽度则大于高度。)设备,在「min-resolution」查询中指定的值必须与最稀疏尺寸进行比较,在「max-resolution」查询中必须与最密集尺寸进行比较。对于「resolution」(没有「min-」或「max-」前缀)从不查询Non-Square Pixels 设备。另外在 CSS image Level 3image-resolution 属性中定义了一些单位,比如「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「3」
「4」

需要注意几点:

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

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

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

  1. background-image:url(http://img02.taobaocdn.com/tps/i2/T10s3JXn4XXXXnbIAn-105-160.png);
  2. background-image: -webkit-image-set(
  3. url(http://img02.taobaocdn.com/tps/i2/T10s3JXn4XXXXnbIAn-105-160.png) 1x,
  4. url(http://img04.taobaocdn.com/tps/i4/T1947tXmJhXXcCfooh-210-320.png) 2x);

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

T1.5wZXfNdXXXx4zQi-562-62.png

以下是一些常见移动设备的「min-device-pixel-ratio」值:
-webkit-min-device-pixel-ratio: 1.0


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


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


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


HTML5 响应式图片

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

  1.  
  2.  

于此同时,其他的一些想法如雨后春笋般涌现出来。截止本文发布时间,最近一次更新是 2013年1月7日,规范示例:

  1.  
  2. Accessible text

  3.  

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

  1.  
  2. foo-superduperhires.jpg 6.5x"
  3. alt="decent alt text for foo.">

复制代码

诚然,任何一个新标准的提出,都会存在各种不同的声音,这是好事,作为网页的最终开发者其实并不太关心实现语法。

HTML5 响应式方法

举报
收藏 0
打赏 0
评论 0
昆明公司建设网站要花费多少钱
网站建设多少钱、公司建网站多少钱、网站制作价格是没有标准的,要以企业实际对网站站的需求及类型而确定,市场上也有人几百块钱

0评论2020-11-26349

昆明公司建设网站要花费多少钱
网站建设多少钱、公司建网站多少钱、网站制作价格是没有标准的,要以企业实际对网站站的需求及类型而确定,市场上也有人几百块钱

0评论2020-11-26315

换成这个绩效薪酬模式,让员工状态爆棚,企业利润倍增
如何制定科学合理的薪酬机制促进目标达成?如何将目标与干部员工薪酬相挂钩?如何制定解放老板、激发员工动力的长效机制?2020年

0评论2020-08-22327

企业文化包括内容
1,经营哲学  经营哲学也称企业哲学,源于社会人文经济心理学的创新运用,是一个企业特有的从事生产经营和管理活动的方法论原

0评论2020-07-17325

如何为摆地摊的人服务 从而在风尖浪口上把握地摊经济商机
如何为摆地摊的人服务一、摆地摊的人有什么样的痛点?1.没有钱2.没货源3.不知道选什么产品更好卖4.怕压货5.怕熬了时间还不挣钱二

0评论2020-06-10270

美家短短数月销售过亿:关系链注入社区团购的新玩法
经过去年的资本加持,整个社区团购赛道在今年势必会进入新一轮的淘汰赛。目前来看,头部玩家还未爆出更大动作,更多是闷头在抢占

0评论2020-03-13298

中国正在发生变化的96点,你知道吗?
1、阿里巴巴、淘宝、京东正在沦为传统企业2、传统互联网不断扩大贫富差距3、移动互联网开始消灭贫富差距4、中国互联网从尾随美国

0评论2019-01-04226

先借力,后能力,先借船,后造船,抱团打天下!
人生路上,首先找到人生的导师,借用成功人士的眼光去选择项目,确定方向,先借力,后能力,先借船,后造船,抱团打天下!人生指

0评论2018-10-13200

刘强东牛津演讲 面对世界顶尖学府的莘莘学子他说了这些
如果真心想成功,不用恐惧、不用迷茫,你只需要每天能够保持一直向前、一直向上、永不停止。当地时间6月12日,京东集团董事局主

0评论2018-09-02996

[PS3模拟器]rpcs3超简单上手指南
第一:准备游戏 文件夹 iso PKG 都可以第二:固件下载准备模拟器论坛 官网都可以下载首先看看rpcs3运行的最低要求!Minimum Requi

0评论2018-05-19835