乾貨 | 10分鐘玩轉PWA

關於PWA

PWA(Progressive Web App), 即漸進式web應用。PWA本質上是web應用,目的是經過多項新技術,在安全、性能、體驗等方面給用戶原生應用的體驗。並且無需像原生應用那樣繁瑣的下載、安裝、升級等操做。html

這裏解釋下概念中的「漸進式」,意思是這個web應用還在不斷地進步中。由於目前而言,PWA尚未成熟到一蹴而就的程度,想在安全、性能、體驗上達到原生應用的效果仍是有不少的提高空間的。一方面是構建PWA的成本問題,另外一方面是目前各大瀏覽器、安卓和IOS系統對於PWA的支持和兼容性還有待提升。jquery

本文我將從網站緩存、http請求攔截、推送到主屏等功能,結合實例操做,一步步引領你們快速玩轉PWA技術。web

Service Worker

Service Worker是PWA的核心技術,它可以爲web應用提供離線緩存功能,固然不只如此,下面列舉了一些Service Worker的特性:json

基於HTTPS 環境,這是構建PWA的硬性前提。( LAMP環境網站升級HTTPS解決方案 )

是一個獨立的 worker 線程,獨立於當前網頁進程,有本身獨立的 worker context瀏覽器

可攔截HTTP請求和響應,可緩存文件,緩存的文件能夠在網絡離線狀態時取到緩存

能向客戶端推送消息安全

不能直接操做 DOM服務器

異步實現,內部大都是經過 Promise 實現微信

Service Worker生命週期

serviceworker的使用流程能夠簡單總結爲註冊--安裝--激活。網絡

註冊
註冊其實就是告訴瀏覽器serviceworkerJS文件存放在什麼位置,而後瀏覽器下載、解析、執行該文件,進而啓動安裝。這裏我建立一個app.js文件,註冊代碼以下,將該文件在網站的head標籤裏引入。

if ('serviceWorker' in navigator) {
    window.addEventListener('load', function () {

                navigator.serviceWorker.register('/sw.js')

                    .then(function (registration) {

                        // 註冊成功

                        console.log('ServiceWorker registration successful with scope: ', registration.scope);

                    })

                    .catch(function (err) {

                        // 註冊失敗:(

                        console.log('ServiceWorker registration failed: ', err);

                    });

            });

        }

安裝
當執行serviceworkerJS文件時,首先觸發的是install事件,進行安裝。安裝的過程就是將指定的一些靜態資源進行離線緩存。下面是個人sw.js文件中的安裝代碼:

var CACHE_VERSION = 'sw_v8';
var CACHE_FILES = [

            '/js/jquery/min.js',

            '/js/zui/min.js',

            '/js/chanzhi.js',

        ];

        self.addEventListener('install', function (event) {

            event.waitUntil(

                caches.open(CACHE_VERSION)

                  .then(cache => cache.addAll(CACHE_FILES)

            ));

        });

激活
當安裝成功後,serviceworker就會激活,這時就會處理 activate 事件回調 (提供了更新緩存策略的機會)。並能夠處理功能性的事件 fetch (請求)、sync (後臺同步)、push (推送)。

self.addEventListener('activate', function (event) {
    event.waitUntil(

                caches.keys().then(function(keys){

                    return Promise.all(keys.map(function(key, i){

                        if(key !== CACHE_VERSION){

                            return caches.delete(keys[i]);

                        }

                    }));

                })

            );

        });

serviceworker的緩存功能

安裝時,serviceworker將咱們指定的靜態資源進行緩存(即預緩存),你也許會問,若是是實時的動態內容怎麼辦,咱們不可能預先將全部的文件資源提早指定好,讓serviceworker緩存。這就要提到serviceworker的攔截HTTP請求響應的特性了。

serviceworker攔截http請求,首先去檢查請求的資源在緩存中是否存在,若是存在,則直接從緩存中調用,並且即使是無網絡狀況下,serviceworker也能調用緩存中的資源。若是緩存中沒有請求的資源,則經過網絡去服務器上檢索,並且在找到並響應時,serviceworker會將其存入緩存中,以備下次再請求時直接從緩存中調用。

serviceworker緩存流程

serviceworker文件中fetch事件代碼以下:

self.addEventListener('fetch', function (event) {
    event.respondWith(
        caches.match(event.request).then(function(response){
            if(response){
                return response;
            }
            var requestToCache = event.request.clone();
            return fetch(requestToCache).then(
              function(response){
                if(!response || response.status !== 200){
                  return response;
                }
                var responseToCache = response.clone();
                caches.open(CACHE_VERSION)
                  .then(function(cache){
                    cache.put(requestToCache, responseToCache);
                  });
                return response;
              }
            );
        })
    );
});

在網站前臺經過瀏覽器開發者工具,咱們能夠看下從緩存中調用資源的效果:

圖片描述
圖片描述

我這裏操做演示用的是谷歌瀏覽器,下面是各大瀏覽器對於serviceworker的支持狀況:

圖片描述

添加到主屏

PWA支持將web應用在主屏桌面上添加一個快捷方式,以方便用戶快速訪問,同時提高web應用重複訪問的概率。你也許會說,如今移動端上的瀏覽器功能列表裏通常都提供了「添加到桌面」的功能呀,可是PWA與瀏覽器自帶的添加到桌面的實現方式不一樣。

PWA不須要用戶刻意去功能列表中使用這個功能按鈕,而是在用戶訪問web應用時,直接在界面中提示一個添加到主屏桌面的橫幅,從web應用角度而言,這其實就是主動與被動的區別。

PWA實現該功能很是簡單,只須要一個manifest.json文件,文件中用戶能夠自定義應用的啓動頁面、模板顏色、圖標等內容。下面是個人manifest.json文件設置,你們可做參考:

{
  "short_name": "蟬知資源站",
  "name": "蟬知資源站",
  "icons": [
    {
      "src": "chanzhiicon.png",
      "type": "image/png",
      "sizes": "48x48"
    },
    {
      "src": "192.png",
      "type": "image/png",
      "sizes": "192x192"
    },
    {
      "src": "512.png",
      "type": "image/png",
      "sizes": "512x512"
    },
    {
      "src": "144.png",
      "type": "image/png",
      "sizes": "144x144"
    }
  ],
  "start_url": "/index.html",
  "display": "standalone",
  "background_color": "#2196F3",
  "orientation": "landscape",
  "theme_color": "#2196F3"
}

須要提醒的是,目前移動端IOS系統的支持並很差,安卓手機上須使用57版本以上的谷歌瀏覽器能夠支持該功能,下面是我在安卓手機上的操做演示:

圖片描述

小結

PWA技術正被廣大企業及開發者們關注,雖然目前各設備的支持兼容有待提升,但這些都正在不斷的改善進步。我也相信在不久的未來,PWA技術會逐步普遍普及,爲廣大企業和用戶帶來便利。本文和你們一塊兒分享了PWA的相關技術與實例操做,後面還會就消息推送、數據同步等功能作進一步探討交流。若是你們在學習PWA的過程當中遇到其餘問題,歡迎一塊兒討論交流。

做者:薛才傑(GavinHsueh),QQ/微信:753391279,專一項目管理、辦公自動化、網站建設等web應用開發領域。
更多技術文章、互動交流,歡迎關注公衆號:
圖片描述

相關文章
相關標籤/搜索