Flipboard发布Web版,在Web技术实现上取得突破

jopen 5年前

原文  http://www.infoq.com/cn/news/2015/04/flipboard-web-version


最近,Flipboard 发布了其杂志形式社交网络聚合阅读器的 Web版本 。这次发布旨在让用户在浏览器中拥有与原生应用同样的阅读体验。为了实现这个目标,开发团队不得不在Web技术上有所突破以满足原生应用对照版本的要求。Web版开发团队的工程师Michael Johnston在Flipboard官方博客上 详细说明 了他们面对的一些问题及解决之道。

开发团队做出的第一个决定是Web版应该滚动展示而不是标准的翻页展示,他们认为在Web环境下,对于用户来说滚动看起来更自然;其次,他们希望用户拥有每秒60帧的体验,这意味着绘制时间应控制在16毫秒之内,且需要限制重排和重绘。因为存在 卡顿 的现象,所以在移动设备上很难做到这一点。在他们看来,DOM非常慢,而且与DOM的交互终将超过这个限制。

综合考虑,他们最终决定使用Canvas,Michael解释说:


Canvas是一个即时模式的绘制API,绘制层不保留绘入对象的信息,而保留模式恰恰相反,它是声明式的API,管理绘入对象的层次结构。Canvas受益于即时模式方式允许直接给GPU发送绘制指令。

与HTML+CSS技术相比,Canvas开发技术面临的困难尤其突出:它每次只能绘制一行文本,图像处理起来很复杂,重叠元素无法参考任何z-index属性。尽管遇到这么多弊端和困难,团队最终仍决定坚持Canvas技术,因为Michael认为:


你不可能在DOM中构建一个每秒60帧的滚动列表视图,与此相反,现今的大多数设备都提供了硬件加速的Canvas实现,可以直接给GPU发送绘制指令。这意味着我们可以非常快地渲染元素;在许多场景下,我们说的是亚毫秒级范围。

事实上,Canvas拥有非常小的API集,能够减少不同浏览器间所现bug或不一致性的可能性。相对于处理绘制指令的严格顺序,创建开发者可以处理节点树的抽象层,无论如何都是更加必要的。为了完成这个库,团队实现了自己的滚动算法(加入了一些优化考虑,如使用脱屏canvas的重绘层),并在 React Canvas (一个React组件,能够以更自然的方式进行Canvas开发)之下封装所有功能。

社区对这次发布的反应褒贬不一,每一个人都赞扬团队为这个项目做出的努力以及他们无私分享他们的决策,即使是那些有争议者。一些人喜欢它的 简洁设计React Canvas的流畅性 ,而不喜欢团队所做决定的其他人主要担忧可访问性的问题。Modernizr的作者Faruk Ateş在他的博客中写到:


Flipboard是一个重点为文字内容的产品,这就是为工程团队将可访问性完全抛出窗外而深感遗憾的原因。整个“Web”版本竟然是在一个HTML5 Canvas元素中用伪DOM(文档对象模型)实现。我也希望易用性是工程团队下一个重大计划──2.0版本发布时要解决的问题,如果你愿意的话。

Christian Heilmann 批评了团队执着于每秒60帧以及无限滚动:


的确,我们需要有目标追求,也需要有可参照衡量的一些东西。但考虑到硬件的不统一,以及一个HTML5应用必须涉及的抽象层数量,定义一些类似每秒60帧基准的事情是相当幼稚的。

大量解决方案都涉及无限滚动,真的,通常这比分页还烦人。

查看英文原文: Flipboard Pushing Boundaries With Its Web Version Release