codecamp

(十):总结

原文出处:http://www.w3cplus.com/responsive/responsive-images-part-10-conclusion.html

我们做到了!我们到了响应式图片101系列的结尾。

在与这个系列就此分别之前,我想给出一些提示,资源和一些关于响应式图片发展的最终思考。

响应式图片审查

本来在这个系列里,我想添加一章响应式图片审查的内容。这是我们开始把页面图片转换成响应式图片时做的第一件事。

很有可能下一步就是使用你学到的东西并应用在页面上。

幸运的是,我最近详细书写了审查内容。所以没有在101系列中重复,我鼓励你阅读我写的关于响应式图片审查的文章。

兼容性

响应式图片标准的浏览器支持在快速发展。到2015年8月,Chrome,Opera和Firefox都支持了 picturesrcsetsizes, 和type.

Microsoft Edge和Safari支持带有显示描述符(x)的srcset,但不支持宽度描述符。Microsoft已经开始了支持所有响应式图片标准的开发

Apple还没有支持该标准,但是Apple清楚支持响应式图片很重要并且Yoav Weiss已经在给Webkit实现做贡献。

对于image-set(),还有做很多工作

PictureFill

然而即便当前所有浏览器都支持响应式图片标准,我们仍然需要一个方法让老版本浏览器兼容新语法。这时候就需要用到PictureFill polyfill

PictureFill让你现在就可以使用新响应式图片语法。

自动化图片处理流程

第9部分里,我说人们不应该手动选择图片断点。应该让软件自动帮我们完成。

我希望在这一点上扩展并且在响应式图片的情况下大部分事情通常程度上不是设计师和开发者应该考虑的。

大多数组织的目标应该把图片缩放当作中心并且尽可能自动处理响应式图片。

理想情况下,解决分辨率切换情况的响应式图片工作流应该如下所示:

  • 当情况允许,使用分辨率无关的SVG图片。
  • 当创建或修改设计模版时,模版作者在模版中提供多种图片的sizes属性。
  • 宽度描述符的srcset属性由服务器来插只入剩下一些轻松的工作例如给每张图片选择图片断点。
  • 内容作者不需要担心。他们唯一的职责是上传可用的最高质量图片然后让图片缩放服务处理其他事情。

这不是遥远的场景。许多组织已经有了图片缩放服务。如果你的组织还没有,我有一个可供参考的图片缩放服务和工具的电子表格(确保同时阅读了说明博文)。

许多内容管理系统开始寻找包含响应式图片的方法。响应式图片讨论组(RICG)维护一个WordPress插件并且他们正在研究如何整合到WordPress核心里。Drupal 8会自带响应式图片模块更多细节)。

这些图片缩放服务需要扩展的一点是计算出对于给定图片需要添加多少图片源并且输出这些图片源的标记。如果使用了服务器提示它们甚至不需要担心标记。

但是无论怎么自动化,我相信以图片缩放和处理为中心对于保持思路清晰非常重要。当我们谈到探索响应式图片的新公司时,需要评估的第一件事情是它们的图片工作流以及多大程度可以实现自动化。

响应式图片未来

我们才刚刚开始探索响应式图片。已经有成千上万的网站更新到了新图片标准。许多组织需要更新处理图片的方式来集中和自动化目前仍然是手动完成的工作。

虽然我们面前还有许多工作,似乎我们终于在下坡路了。我们不再需要与寻找每个人都同意的解决方案做斗争。浏览器支持正逐步实现。PictureFill帮我们弥补漏洞。

现在网页开发讨论组开始研究如何实现这些新标准,这意味着我们可以开始互相学习。

如果你已经阅读了整个101系列,那么你就已经有了开始使用响应式图片的所有东西。我对于你会使用新标准做什么已经迫不及待了。请分享你所学到的!

感谢阅读。

(九):图片断点
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }