如何让Angular支持Service Worker

前两天 angular.io 发布新版本,一开始以为只是界面样式做了一些变动,后来为了查资料怎么发现打开的速度简直牛B了(要知道在天朝打开angular.io多么费劲啊)。然后我到twitter中了解angular进展,竟然这一次官网新版本是为了试验 Service Worker。

什么是Service Worker

一直对 Service Worker 很关注,离线体验、定期同步、推送通知等这些光环多么久让向往呀。

Service Worker 可以使你的应用先访问本地缓存资源,所以在离线状态时,在没有通过网络接收到更多的数据前,仍可以提供基本的功能(一般称之为 Offline First)。这是原生APP 本来就支持的功能,这也是相比于 web app,原生 app 更受青睐的主要原因。

有关于更多关于Service Worker的定义请参与MDN。

Angular Service Worker

应该说Angular一开始就对Service Worker的支持,只不过受限于浏览器一些硬性,所以一直好像都没有什么人谈及。

直到这一次……

而本文会根据一个简单的示例,让我们一起了解Service Worker在Angular的运用。

1、前提条件

Service Worker 需要一些前提条件,大概是:

  • 浏览器是否支持Service Worker。
  • Service Worker 请求协议必须是 HTTPS。(但我实测使用http-server运行并无须https)

2、安装与运行

官网提供一个 @angular/service-worker 按官方大概会在 Angular4.3.0 时移入 @angular/core 中,可见这地位多少重要啊。

当然啦,目前是试验性,所以如果您体验它,需要以下设置:

npm install @angular/service-worker --save
ng set apps.0.serviceWorker=true

现在我们必须运行 ng build -prod 构建生产版本,对于 ng serve 并不会启动Service Worker,这样 Service Worker 配置信息自动添加到我们的项目当中。

最后,利用静态服务器,运行 ./dist

http-server ./dist

当你首次打开 http://127.0.0.1:8080/ 后会自动缓存我们angular生产文件包,这一点,可以通过Chrome > dev tools > Application > Service Worker 加以验证。

那么,接下来当你断点 http-server 服务后,依然能访问 http://127.0.0.1:8080/

3、我好像什么都没有做!

是的,我们的确什么都没有做,这一切 angular cli 都帮忙了。我们可以通过 ./dist 了解一些细节。

Service Worker配置

ngsw-manifest.json 是 Service Worker 配置文件。

{
  "static": {
    "urls": {
      "/polyfills.a7151445bffeeb4c3ed1.bundle.js": "8562b2db4e35a23f44238e4f047e511f1a68c84d",
////////////////////all static files////////////////////
      "/index.html": "0511d96f8521033a561c607afc9ec7f168e7d358"
    },
    "_generatedFromWebpack": true
  }
}

这是Angular Cli默认生成的配置信息,里面是将 ./dist 文件夹的所有(包括assets)的路径写入 urls 节点中。

不过这个配置文件我们可以进行自定义,只需要创建 ./src/ngsw-manifest.json 文件。当然这样我们可以配置更多细节的内容。

当前的Angular Cli 1.1.1/1.2.0-beta.1无法自定义ngsw-manifest.json #6654,所以只能期望工具的跟上,当然这一切只是时间的问题。

static.urls(支持正则)

需要缓存的文件清单。

static.ignore(支持正则)

忽略缓存的文件清单。

static.versioned(支持正则)

Service Worker 会根据此规则来判断文件是否需要同步,像Webpack构建的文件名中会有哈希值,这样 Service Worker 就不需要获取文件后才知道是不是最新版本了。

externals

需要缓存的外部文件,比如我们 iconfont.cn 的在线文件。

routing

缓存路由。


  "routing": {
    "index": "/index.html",
    "routes": {
      "/(?!e?plnkr)[^/.]*$": {
        "match": "regex" // or "exact"
      }
    }
  }

dynamic

缓存策略配置。

{
  "dynamic": {
    "group": {
      "name": "hi-service-worker",
      "cache": {
        "optimizeFor": "freshness",
        "maxAgeMs": "3600000",
        "maxEntries": "20",
        "strategy": "lru"
      }
    }
  }
}

PWAs

如果你是Google技术宅,那么这个名词应该不陌生。

PWAs是指2017年2月4日,谷歌推出的“小程序”增强型网页应用( Progressive Web Apps,简称 PWAs),它无需下载安装,却可以和本地APP一样,放置在桌面上。

而愿景交由你自己想象吧!

结论

在 Angular 世界里,我们只需要通过简单的配置就能让现有 Angular APP 快速、可靠的支持Service Worker,这是一件多么让愉快的事情呀!

happy coding!

你可能感兴趣的:(如何让Angular支持Service Worker)