[翻译]Angular Service Worker 介绍

原文
Service workers 使用原生js代码增强了传统web应用,使用户体验到更高的可靠性与更好的体验。

Service worker只是一个运行在浏览器端并可为应用管理缓存的脚本

Service workers 是作为一个客户端代理。它们拦截所有应用的http请求,然后自定义如何去回复。例如:它们可以查询本地的缓存,可以直接把缓存作为回复内容。这些代理不限于api的请求,还包括在HTML里的资源请求还有index.html里的初始化请求。基于Service workers的缓存是完全可编程的,不依赖于服务器指定的缓存头。

不像如angular应用的bundle脚本,在关闭页面后就消失了,service worker 是可以一直保留的。下次在同一浏览器打开应用,service worker是首先加载的,并可以拦截所有的资源请求。如果你的service worker是如此配置的,它就可以在无网络的情况下完成应用的加载。

即使在一个快速可靠的网络中,往返延迟也会在加载应用程序时产生严重的延迟。使用service worker减少对网络的依赖并可显着改善用户体验。

Angular的Service workers

利用service workers的长处可很好改善如angular一样的单页面应用。从5.0.0开始,angular加入了service worker。angular开发人员可以利用service workers去提高应用的可靠性与性能,不再需要在低层面的API层去部署。

angular的service worker是设计去优化处于低网速或不稳定网络的终端用户的体验,同时也减少提供过期数据的风险

angular的service worker的行为遵循以下的设计目标:

  • 缓存一个应用就像安装一个原生的应用。这应用是被作为一个整体去缓存并一同更新。

  • 一个在执行的应用是会继续使用同一版本的所有文件。它不会突然从新版本中接收新的缓存,因为很可能会前后互相冲突

  • 当用户刷新应用,他们能看到最近的缓存版本。新的tab页会加载最近的缓存脚本。

  • 应用更改并发布后,缓存的更新是在后台执行,而且十分快速。在更新完成前,旧版本会一直继续服务。

  • service worke尽可能的节省带宽。只会在资源被修改后重新下载资源。

要支持以上的行为,angular的service worker从服务中加载一个manifest 文件。这个文件定义了要缓存的资源表,同时包括各资源内容的hashes码。当应用更新了,manifest文件也会被修改,然后通知service worker去下载新版本并作缓存。这个manifest文件是根据用户提供的配置文件ngsw-config.json去生成,这一步可依靠如Angular CLI的工具去实现

加入 Angular service 是十分简单,只需要修改 NgModule。在里面注册service worker就好,然后angular会自动注入服务,然后service worker就可以获得应用的控制权。例如,应用可以在有可用更新时获得通知,或者应用可以要求service worker去检查是否有可用的更新。

前置配置

为了使用angular的service workers,你必须是以下的Angular 和 CLI 的版本:

  • 不低于Angular 5.0.0r.
  • 不低于Angular CLI 1.6.0.

你的应用必须运行在支持service workers的浏览器中。最新版本的Chrome 和 Firefox 都支持。可通过可以用吗 页面去看各浏览对service worker的支持情况。

相关资源

想了解service worker,请看介绍Service Workers.

关于浏览器的支持,请看浏览器的支持介绍Service Workers, Jake Archibald的 Serviceworker准备好了吗, and 可以用吗.

其余的文档会继续深入service worker

更多的关于Angular service workers

你可能对以下感兴趣

你们的赞赏是我的无限动力

如果觉得文章对你有点用的话,麻烦拿出手机,这里有一个你我都有的小福利(每天一次): 打开支付宝首页搜索“8601304”,即可领红包。谢谢支持

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