欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解使用angular框架離線你的應(yīng)用(pwa指南)

 更新時(shí)間:2019年01月31日 11:09:43   作者:野生爬山虎  
這篇文章主要介紹了詳解使用angular框架離線你的應(yīng)用(pwa指南),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

簡介

關(guān)于service worker,網(wǎng)絡(luò)上已經(jīng)有了較多的文章??偟膩碚f它依靠緩存資源,攔截http請求,來幫助我們達(dá)到離線使用網(wǎng)站的效果。

而angular cli為了讓使用service worker更加便利,為開發(fā)者提供了一個(gè)配置窗口(ngsw-config.json)和一個(gè)與service worker通訊的服務(wù)(SwUpdate)。

啟用

1、新建項(xiàng)目后在項(xiàng)目根目錄下鍵入ng add @angular/pwa。

會(huì)為你的項(xiàng)目添加一些文件,其中包括上文提到的ngsw-config.json,為了即刻感受離線應(yīng)用的魅力,現(xiàn)暫不需配置。

2、安裝http-server npm install http-server -g

將用http-server啟用的服務(wù)器來加載應(yīng)用,這么做是為了模擬真實(shí)的生產(chǎn)環(huán)境,因?yàn)閚g serve環(huán)境下無法啟用service worker。

3、鍵入ng build --prod進(jìn)行打包。 打包完成后進(jìn)入dist下的項(xiàng)目根目錄下,鍵入http-server -p <port>將打包后的應(yīng)用部署在http-server指定的端口上。

4、打開瀏覽器進(jìn)入控制臺(tái),以chrome為例,在network選項(xiàng)卡上勾選offline模擬離線使用。

此時(shí)重新刷新網(wǎng)頁發(fā)現(xiàn)頁面依然能夠在離線狀態(tài)下顯示,說明service worker已經(jīng)工作了。

配置

以上并沒有手動(dòng)配置ngsw-config.json,然而初始的配置還有許多不足,比如無法攔截緩存api請求。因此需要對該文件的配置參數(shù)做一個(gè)大概了解(點(diǎn)擊瀏覽官方配置說明)。

參考官方的說明,我們了解到可以配置靜態(tài)資源的緩存策略(配置項(xiàng)中的assetGroups)以及動(dòng)態(tài)資源的緩存策略(配置項(xiàng)中的dataGroups)。

靜態(tài)資源配置(assetGroups)

interface AssetGroup {
 name: string;
 installMode?: 'prefetch' | 'lazy';
 updateMode?: 'prefetch' | 'lazy';
 resources: {
  files?: string[];
  /** @deprecated As of v6 `versionedFiles` and `files` options have the same behavior. Use `files` instead. */
  versionedFiles?: string[];
  urls?: string[];
 };
}

這是該配置項(xiàng)的接口,下面對各個(gè)屬性做一個(gè)簡要的說明:

  • resources屬性下可配置本地的靜態(tài)資源(resources.files)和通過cdn來的靜態(tài)資源(resources.urls)
  • name是需要編寫的該資源集合的唯一的名字
  • installMode配置的是你的網(wǎng)站應(yīng)用第一次在當(dāng)前瀏覽器加載后,service worker應(yīng)該進(jìn)行的緩存策略。選擇'prefetch'會(huì)將resources列出的資源一股腦兒的預(yù)先緩存起來,不管當(dāng)前是否有訪問到。選擇'lazy'則不會(huì)預(yù)先緩存,而是在用到時(shí)才會(huì)進(jìn)行緩存。
  • updateMode配置的是當(dāng)檢測到資源的版本改變之后,所進(jìn)行的資源緩存策略。

如何得知資源的版本發(fā)生了變化呢?angular service worker會(huì)對比資源內(nèi)容的hash值。如果hash值不同則版本不同。選擇'prefetch'會(huì)立即緩存更新的資源,選擇'lazy'會(huì)在用到時(shí)在進(jìn)行緩存。不過,這里要注意如果在installMode的配置中沒有選擇'lazy'模式,則這里的'lazy'模式也不會(huì)生效。

動(dòng)態(tài)資源配置(dataGroups)

export interface DataGroup {
 name: string;
 urls: string[];
 version?: number;
 cacheConfig: {
  maxSize: number;
  maxAge: string;
  timeout?: string;
  strategy?: 'freshness' | 'performance';
 };
}

這是緩存動(dòng)態(tài)資源的配置項(xiàng),其實(shí)就是緩存的ajax、fetch的response,將這些api請求的響應(yīng)體進(jìn)行緩存后,就可以在離線狀態(tài)下使用。其中:

  • urls配置api的url
  • cacheConfig配置具體的緩存策略:
    • maxSize 緩存的最大條目數(shù)或響應(yīng)數(shù),太多則會(huì)暫用系統(tǒng)資源
    • maxAge 過期時(shí)間,該項(xiàng)與下面提到的strategy策略配合,如果設(shè)置過長,容易呈現(xiàn)老資源給用戶。
    • timeout是指的應(yīng)用發(fā)起真實(shí)網(wǎng)絡(luò)請求后的等待時(shí)間,如果超時(shí)將會(huì)配合下面提到的strategy進(jìn)行動(dòng)作
    • strategy策略,選擇'performance'會(huì)直接攔截網(wǎng)絡(luò)請求,返回緩存(前提是有緩存,并且沒有超過maxAge的時(shí)間),選擇'freshness'會(huì)在timeout超時(shí)的時(shí)候返回緩存。

與service worker通訊

與service worker通訊可以讓我們主動(dòng)做很多事情,而不是僅僅依賴于ngsw-config.json配置,通過依賴注入一個(gè)SwUpdate*服務(wù),我們可以主動(dòng)要求查詢、更新、激活應(yīng)用的版本,(這部分內(nèi)容筆者還未投入應(yīng)用,詳見官網(wǎng)描述)

總結(jié)

這篇文章我們分享了如何在angular里面使用service worker 進(jìn)行離線場景的增強(qiáng),其中包括

  • 引入@angular/pwa
  • 安裝http-server,模擬生產(chǎn)環(huán)境
  • 配置ngsw-config.json 緩存策略
  • 簡單描述了與service worker通訊的概念

相信今后angular框架能夠在pwa應(yīng)用方便給我們更多的方便。以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解為Angular.js內(nèi)置$http服務(wù)添加攔截器的方法

    詳解為Angular.js內(nèi)置$http服務(wù)添加攔截器的方法

    所謂攔截器就是在目標(biāo)達(dá)到目的地之前對其進(jìn)行處理以便處理結(jié)果更加符合我們的預(yù)期。Angular的$http攔截器是通過$httpProvider.interceptors數(shù)組定義的一組攔截器,每個(gè)攔截器都是實(shí)現(xiàn)了某些特定方法的Factory。本文就介紹了為Angular.js內(nèi)置$http服務(wù)添加攔截器的方法。
    2016-12-12
  • 使用Angular內(nèi)置模塊進(jìn)行HTTP請求

    使用Angular內(nèi)置模塊進(jìn)行HTTP請求

    這篇文章主要介紹了使用Angular內(nèi)置模塊進(jìn)行HTTP請求方法步驟詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • Angular.js如何從PHP讀取后臺(tái)數(shù)據(jù)

    Angular.js如何從PHP讀取后臺(tái)數(shù)據(jù)

    這篇文章主要為大家簡單介紹了Angular.js如何從PHP讀取后臺(tái)數(shù)據(jù),本文將Angular和PHP相結(jié)合,從后臺(tái)讀取數(shù)據(jù),感興趣的小伙伴們可以參考一下
    2016-03-03
  • 詳解angular用$sce服務(wù)來過濾HTML標(biāo)簽

    詳解angular用$sce服務(wù)來過濾HTML標(biāo)簽

    這篇文章主要介紹了詳解angular用$sce服務(wù)來過濾HTML標(biāo)簽,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-04-04
  • AngularJS通過ng-route實(shí)現(xiàn)基本的路由功能實(shí)例詳解

    AngularJS通過ng-route實(shí)現(xiàn)基本的路由功能實(shí)例詳解

    這篇文章主要介紹了AngularJS通過ng-route實(shí)現(xiàn)基本的路由功能,結(jié)合實(shí)例形式詳細(xì)分析了AngularJS使用ng-route實(shí)現(xiàn)路由功能的操作步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2016-12-12
  • Angular.JS讀取數(shù)據(jù)庫數(shù)據(jù)調(diào)用完整實(shí)例

    Angular.JS讀取數(shù)據(jù)庫數(shù)據(jù)調(diào)用完整實(shí)例

    這篇文章主要介紹了Angular.JS讀取數(shù)據(jù)庫數(shù)據(jù)調(diào)用,結(jié)合完整實(shí)例形式分析了AngularJS使用$http.get方法與后臺(tái)php交互讀取數(shù)據(jù)庫數(shù)據(jù)相關(guān)操作技巧,需要的朋友可以參考下
    2019-07-07
  • Angular 7工作方式事件綁定

    Angular 7工作方式事件綁定

    在本章中將討論事件綁定在Angular7中的工作方式,當(dāng)用戶以鍵盤移動(dòng),鼠標(biāo)單擊或鼠標(biāo)懸停的形式與應(yīng)用程序交互時(shí),它將生成一個(gè)事件,需要處理這些事件以執(zhí)行某種操作,考慮一個(gè)示例以更好地理解這一點(diǎn)
    2023-12-12
  • AngularJS基礎(chǔ) ng-switch 指令簡單示例

    AngularJS基礎(chǔ) ng-switch 指令簡單示例

    本文主要講解AngularJS ng-switch 指令,這里對ng-switch 指令的基礎(chǔ)資料做了詳細(xì)整理,并附代碼示例,有興趣的小伙伴可以參考下
    2016-08-08
  • AngularJS上拉加載問題解決方法

    AngularJS上拉加載問題解決方法

    這篇文章主要介紹了AngularJS上拉加載問題解決方法的相關(guān)資料,該問題在項(xiàng)目中一直存在,小編給大家分享解決辦法,需要的朋友可以參考下
    2016-05-05
  • Angular ElementRef簡介及其使用

    Angular ElementRef簡介及其使用

    這篇文章主要介紹了Angular ElementRef簡介及其使用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-10-10

最新評論