使用 React.js 的渐进式 Web 应用程序:第 1 部分 - 介绍

来自译者 markzhai:大家也知道最近 Web 越来越火了,如果你还以为 Web 就是 jQuery、Ajax、CSS 什么的,那你就 out 了。给大家几个链接看一看吧:

部分可能需要自备梯子,另外建议在 Chrome 下查看,毕竟该死的 X5,大家都懂得。

使用 React.js 的渐进式 Web 应用程序:第 1 部分 - 介绍

渐进式 Web 应用程序利用新技术的优势带给了用户最佳的移动网站和原生应用。它们是可靠的,迅捷的,迷人的。它们来自可靠的源,而且无论网络状态如何都能加载。

渐进式 Web 应用程序 (PWAs) 的世界中有很多新东西,你可能会想知道它们和现有架构是如何兼容的 —— 比如 React 和 JS ??榛虬ぞ呷?Webpack 之间的兼容性如何。PWA 是否需要大量的重写?你需要关注哪个 Web 性能度量工具?在这系列的文章中,我将会分享将基于 React 的 web apps 转化为 PWAs 的经验。我们还将包括为什么加载用户路由所需要的,并抛开其他所有脚本是提高性能的好方式。

Lighthouse

让我们从一个 PWA manifest 开始。为此我们会使用 Lighthouse?—?一个评审 app 面向 PWA 特性 的工具,并且检查你的 app 在模拟移动场景下是否做的足够好。Lighthouse 可以通过 Chrome 插件 (我大部分时候都用这个) 以及 CLI 来使用,两者都会展示一个类似这样的报告:

来自 Lighthouse Chrome 插件的结果

顶级评审工具 Lighthouse 会高效地运行一系列为移动世界精炼的现代 web 最佳实践:

  • 网络连接是安全的
  • 用户会被提醒将 app 添加到 Homescreen
  • 安装了的 web app 启动时会带自定义的闪屏画面
  • App 可以在离线/断断续续的连接下加载
  • 页面加载性能快速
  • 设计是移动友好的
  • 网页是渐进式增强的
  • 地址栏符合品牌颜色

顺便一提,有一个 Lighthouse 的 快速入门指南,而且它还能通过 远程调试 工作。超级酷炫。

无论在你的技术栈中使用了什么库,我想要强调的是在上面列出的一切,在今天都只需要一点小小的工作量就能完成。然而也有一些警告。

我们知道移动 web 是 慢的

web 从一个以文档为中心的平台演变为了头等的应用平台。同时我们主要的计算能力也从强大的,拥有快速可靠的网络连接的强大桌面机器移动到了相对不给力的,连接通常慢,断断续续或者两者都存在的移动设备上。这在下一个 10 亿用户即将上网的世界尤其真实。为了解锁更快的移动 web:

  • 我们需要全体转移到在真实移动设备,现实的网络连接下进行测试 (e.g 在 DevTools 的常规 3G)。 chrome://inspectWebPageTest (视频) 是你的好帮手。Lighthouse 模拟一台有触摸事件的 Nexus 5X 设备,以及 viewport 仿真 和 被限制的网络连接 (150毫秒延迟,1.6Mbps 吞吐量)。
  • 如果你使用的是设计开发时没有考虑移动设备的 JS 库,你可能会为了可交互性能打一场硬仗。我们的理想化目标是在一台响应式设备上 5 秒内变得可交互,所以我们应用代码的预算会更多是 ?

通过一些工作,可以写出 如 Housing.com 所展示的 在有限网络环境下,真机上依然表现良好的使用 React 开发的 PWAs。我们在接下来的系列中讨论如何实现的详尽 细节。

话虽如此,这是一个很多库都在尽力提高的领域,你可能需要知道他们是否会继续提高在物理设备上的性能。只需要看看 Preact 所做的超级棒的 真实世界设备的性能。

开源 React 渐进式 Web App 示例

如果你想要看更复杂的使用 React 开发,并使用 Lighthouse 优化的 PWAs 例子,你可能会感兴趣于: ReactHN—?一个使用服务端渲染并支持离线的 HackerNews 客户端 或者 iFixit?—?一个使用 React 开发,但使用了 Redux 进行状态管理的硬件修复指南 app。

现在让我们梳理一遍在 Lighthouse 报告中需要清点的每一项,并在系列中继续 React.js 专用的小贴士。

网络连接是安全的

HTTPS 的工具和建议

HTTPS 防止坏人篡改你的 app 和你的用户使用的浏览器之间的通信,你可能读过 Google 正在推动 羞辱 那些没有加密的网站。强大的新型 web 平台 APIs,像 Service Worker,require 通过 HTTPS ?;だ丛?,但是好消息是像是 LetsEncrypt 这样的服务商提供了免费的 SSL 证书,便宜的选择像是 Cloudflare 可以使端到端流量 完全 加密,从来没有如此简单直接地能做到现在这样。

作为我的个人项目,我通?;岵渴鸬?Google App Engine,它支持通过 appspot.com 域名的 SSL 通信服务,只需要你加上 ‘secure’ 参数到你的 app.yaml 文件。对于需要 Node.js 支持 Universal 渲染的 React apps,我使用 Node on App Engine。Github PagesZeit.co 现在也支持 HTTPS。

这个 Chrome DevTools Security 面板 允许你印证安全证书和混合内容错误的问题。

一些更多的小贴士可以使你的网站更加安全:

  • 根据需要重定向用户,升级非安全请求(“HTTP” 连接)到 “HTTPS”。可以一看 内容安全策略升级非安全请求。
  • 更新所有引用 “http://” 的链接到 “https://”。如果你依赖第三方的脚本或者内容,跟他们商量一下让他们也支持一下 HTTPS 资源。
  • 提供页面的时候,使用 HTTP 严格传输安全 (HSTS) 头。这是一个强制浏览器只通过 HTTPS 和你的网站交流的指令。

我建议去看看 Deploying HTTPS: The Green Lock and BeyondMythbusting HTTPS: Squashing security’s urban legends 来了解更多。

用户会被提醒将 app 添加到 Homescreen

下一个要讲的是自定义你的 app 的 “添加到主屏幕” 体验(favicons,显示的应用名字,方向和更多)。这是通过添加一个 Web 应用 manifest 来做的。我经?;嵴叶ㄖ频目玟榔鳎ㄒ约跋低常┑耐急昀赐瓿烧獠糠止ぷ?,但是像是 realfavicongenerator.net 这样的工具能解决不少麻烦的事情。

有很多关于一个网站只需要在大部分场合能工作的 “最少” favicons 的讨论。Lighthouse 提议 提供一个 192px 的图标给主屏幕,一个 512px 的图标给你的闪屏。我个人坚持从 realfavicongenerator 得到的输出,除了它包含更多的 metatags, 我也更倾向于它能涵盖我的所有基数。

一些网站可能更倾向于为每个平台提供高度定制化的 favicon。我推荐去看看 设计一个渐进式 Web App 图标 以获得更多关于这个主题的指导。

通过 Web App manifest 安装,你还能获得 app 安装器横幅,让你有方法可以原生地提示用户来安装你的 PWA,如果他们觉得会经常使用它的话?;箍梢?延迟 提示,直到用户和你的 app 进行了有意义的交互。Flipkart 找到 最佳时间来显示这个提示是在他们的订单确认页。

Chrome DevTools Application 面板 支持通过 Application > Manifest 来查看你的 Web App manifest:

它会解析出列在你的 manifest 清单文件的 favicons(网站头像),还能预览像是 start URL 和 theme colors 这样的属性。顺带一提,如果感兴趣的话,这里有一个完整的关于 Web App Manfests 的工具小贴士 片段 ??

安装了的 web app 启动时会带自定义的闪屏画面

在旧版本的 Android Chrome 上,点击主屏幕上的 app 图标通常会花费 200 毫秒(一些慢的网站甚至要数秒)以到达文档的第一帧被渲染到屏幕上。

在这段时间内,用户会看到一个白屏,减少对你网站的感知到的性能。Chrome 47 和以上版本 支持自定义闪屏(基于来自 Web App manifest 的背景颜色,名字和图标)会在浏览器准备绘制一些东西前给屏幕一些颜色。这使得你的 webapp 感受上更接近 “原生”。

Realfavicongenerator.net 现在还支持根据你的清单(manifest)预览并自定义闪屏,很方便地节约时间。

注意:Firefox for Android 和 Opera for Android 也支持 Web 应用程序清单,闪屏和添加到主屏幕的体验。在 iOS 上,Safari 也支持自定义添加到 主屏幕的图标 并曾经支持一个 专有的闪屏 实现,然而这个在 iOS9 上显得不能用了。我已经填了一个特性请求给 Webkit,以支持 Web App manifest,所以...希望一切顺利吧。

设计是移动友好的

为多种设备所优化的 Apps 必须在他们的 document 里面包括一个 meta-viewport。这看上去非常明显,但是我看到过很多的 React 项目中,人们忘了加上这个。好在 create-react-app 有默认加上有效的 meta-viewport,而且如果缺失的话 Lighthouse 会标记上:

尽管我们非常重视渐进式 Web 应用程序在移动 web 的体验,这 并不意味着桌面应该被忘记。一个精心设计的 PWA 应该可以在各种 viewport 尺寸、浏览器以及设备上良好运作,正如 Housing.com 所展示的:

在系列第 2 部分,我们将会看看那 使用 React 和 Webpack 的页面加载性能。我们会深入 code-splitting(代码分割),基于路由的 chunking(分块)以及 达到更快交互性 PRPL 模式。

如果你不熟悉 React,我发现 Wes Bos 写的 给新手的 React 很棒。

感谢 Gray Norton, Sean Larkin, Sunil Pai, Max Stoiber, Simon Boudrias, Kyle Mathews 和 Owen Campbell-Moore 的校对

原文见:http://blog.zhaiyifan.cn/2016/11/14/pwa-react-p1/

最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352

推荐阅读更多精彩内容