成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

用Service Worker實(shí)現(xiàn)離線應(yīng)用

jindong / 3198人閱讀

摘要:同時(shí)抓取一個(gè)請(qǐng)求及其響應(yīng),并將其添加到給定的。返回一個(gè)對(duì)象,的結(jié)果是對(duì)象值組成的數(shù)組。代碼以下是一個(gè)實(shí)現(xiàn)離線應(yīng)用的這個(gè)是一個(gè)簡(jiǎn)陋的離線應(yīng)用,會(huì)緩存所有靜態(tài)資源請(qǐng)求,即使你修改了和文件,刷新頁(yè)面還是沒(méi)有變化。

開(kāi)始有興趣了解Service Worker,是因?yàn)閷W(xué)習(xí)react時(shí)使用create-react-app創(chuàng)建的應(yīng)用,src下面會(huì)有一個(gè)registerServiceWorker.js文件。后來(lái)在了解PWA時(shí)也看到了它的身影。于是就打算寫(xiě)一篇筆記詳細(xì)了解一下。

什么是Service Worker
Service workers essentially act as proxy servers that sit between web applications, and the browser and network (when available). They are intended to (amongst other things) enable the creation of effective offline experiences, intercepting network requests and taking appropriate action based on whether the network is available and updated assets reside on the server. They will also allow access to push notifications and background sync APIs.

— from MDN

翻譯過(guò)來(lái)就是:Service workers 本質(zhì)上充當(dāng)Web應(yīng)用程序與瀏覽器之間的代理服務(wù)器,也可以在網(wǎng)絡(luò)可用時(shí)作為瀏覽器和網(wǎng)絡(luò)間的代理。它們旨在(除其他之外)使得能夠創(chuàng)建有效的離線體驗(yàn),攔截網(wǎng)絡(luò)請(qǐng)求并基于網(wǎng)絡(luò)是否可用以及更新的資源是否駐留在服務(wù)器上來(lái)采取適當(dāng)?shù)膭?dòng)作。他們還允許訪問(wèn)推送通知和后臺(tái)同步API。

service worker運(yùn)行在非主線程的其他線程上,所以不會(huì)阻塞主線。,有自己獨(dú)立的上下文,不能訪問(wèn)DOM。只能使用異步api。并且為了安全,service worker只能運(yùn)行在https之上。部分瀏覽器的隱私模式也無(wú)法使用。

由于service workers是由chrome提出推廣的技術(shù),所以chrome支持最好。其他瀏覽器的支持情況就參考Can I Use了:

生命周期

盜用MDN的一張圖。

離線應(yīng)用相關(guān)接口

CacheStorage 在瀏覽器上的引用名叫 caches,CacheStorage 是多個(gè) Cache 的集合,而每個(gè) Cache 可以存儲(chǔ)多個(gè) Response 對(duì)象。雖然它是被定義在 ServiceWorker 的規(guī)范中,但可以在其他worker和window中使用。

caches上調(diào)用 open 方法就可以異步地得到一個(gè)Cache對(duì)象的引用。

Cache.match(request, options)

返回一個(gè)Promise對(duì)象,resolve的結(jié)果是跟Cache對(duì)象匹配的第一個(gè)已經(jīng)緩存的請(qǐng)求。

Cache.matchAll(request, options)

返回一個(gè)Promise 對(duì)象,resolve的結(jié)果是跟Cache對(duì)象匹配的所有請(qǐng)求組成的數(shù)組。

Cache.add(request)

抓取這個(gè)URL, 檢索并把返回的response對(duì)象添加到給定的Cache對(duì)象.這在功能上等同于調(diào)用 fetch(), 然后使用 Cache.put() 將response添加到cache中.

Cache.addAll(requests)

抓取一個(gè)URL數(shù)組,檢索并把返回的response對(duì)象添加到給定的Cache對(duì)象。

Cache.put(request, response)

同時(shí)抓取一個(gè)請(qǐng)求及其響應(yīng),并將其添加到給定的cache。

Cache.delete(request, options)

搜索key值為request的Cache條目。如果找到,則刪除該Cache條目,并且返回一個(gè)resolve為true的Promise對(duì)象;如果未找到,則返回一個(gè)resolve為false的Promise對(duì)象。

Cache.keys(request, options)

返回一個(gè)Promise對(duì)象,resolve的結(jié)果是Cache對(duì)象key值組成的數(shù)組。

代碼

以下是一個(gè)實(shí)現(xiàn)離線應(yīng)用的demo - ServiceWorkerDemo

這個(gè)demo是一個(gè)簡(jiǎn)陋的離線應(yīng)用,會(huì)緩存所有靜態(tài)資源請(qǐng)求,即使你修改了index.js和index.css文件,刷新頁(yè)面還是沒(méi)有變化。要想看到新的變化,必須更改CACHE_KEY或者修改fetch事件的處理邏輯。

const CACHE_KEY = "demo";
const CACHE_FILES = [
    "/",
    "bg.jpg",
    "index.js",
    "index.css"
];


self.addEventListener("install", function(event) { // 監(jiān)聽(tīng)worker的install事件
    event.waitUntil( // 延遲install事件直至緩存初始化完成
        caches.open(CACHE_KEY)
            .then(function(cache) {
                console.log("Cache created");
                return cache.addAll(CACHE_FILES);
            })
    );
});

self.addEventListener("activate", function(event) { // 監(jiān)聽(tīng)worker的activate事件
    event.waitUntil( // 延遲activate事件直到cache初始化完成
        caches.keys().then(function(keys) {
            return Promise.all(keys.map(function(key, i) { // 清除舊版本緩存
                if (key !== CACHE_KEY) {
                    return caches.delete(keys[i]);
                }
            }))
        })
    )
});

self.addEventListener("fetch", function(event) { // 攔截資源請(qǐng)求
    event.respondWith( // 返回資源請(qǐng)求
        caches.match(event.request).then(function(res) { // 判斷是否命中緩存
            if (res) {  // 返回緩存的資源
                return res;
            }
            fallback(event); // 執(zhí)行請(qǐng)求備份操作
        })
    )
});

function fallback(event) {  // 恢復(fù)原始請(qǐng)求
    const url = event.request.clone();
    return fetch(url).then(function(res) { // 請(qǐng)求資源
        //if not a valid response send the error
        if (!res || res.status !== 200 || res.type !== "basic") {
            return res;
        }

        const response = res.clone();

        caches.open(CACHE_KEY).then(function(cache) { // 緩存從剛剛下載的資源
            cache.put(event.request, response);
        });

        return res;
    })
}
其他用途

消息推送

后臺(tái)消息傳遞

網(wǎng)絡(luò)代理,轉(zhuǎn)發(fā)請(qǐng)求,偽造響應(yīng)

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/89545.html

相關(guān)文章

  • 【PWA學(xué)習(xí)與實(shí)踐】(3) 讓你的WebApp離線

    摘要:學(xué)習(xí)與實(shí)踐系列文章已整理至學(xué)習(xí)手冊(cè),文字內(nèi)容已同步至。本文是學(xué)習(xí)與實(shí)踐系列的第三篇文章。引言其中一個(gè)令人著迷的能力就是離線可用。但是,如果你注意到文章開(kāi)頭的圖片就會(huì)發(fā)現(xiàn),離線時(shí)我們不僅可以訪問(wèn),還可以使用搜索功能。 《PWA學(xué)習(xí)與實(shí)踐》系列文章已整理至gitbook - PWA學(xué)習(xí)手冊(cè),文字內(nèi)容已同步至learning-pwa-ebook。轉(zhuǎn)載請(qǐng)注明作者與出處。 本文是《PWA學(xué)習(xí)與實(shí)...

    since1986 評(píng)論0 收藏0
  • Service Worker實(shí)現(xiàn)離線應(yīng)

    摘要:同時(shí)抓取一個(gè)請(qǐng)求及其響應(yīng),并將其添加到給定的。返回一個(gè)對(duì)象,的結(jié)果是對(duì)象值組成的數(shù)組。代碼以下是一個(gè)實(shí)現(xiàn)離線應(yīng)用的這個(gè)是一個(gè)簡(jiǎn)陋的離線應(yīng)用,會(huì)緩存所有靜態(tài)資源請(qǐng)求,即使你修改了和文件,刷新頁(yè)面還是沒(méi)有變化。 開(kāi)始有興趣了解Service Worker,是因?yàn)閷W(xué)習(xí)react時(shí)使用create-react-app創(chuàng)建的應(yīng)用,src下面會(huì)有一個(gè)registerServiceWorker.js...

    2json 評(píng)論0 收藏0
  • 構(gòu)建離線web應(yīng)(一)

    摘要:我喜歡移動(dòng),而且也是那些堅(jiān)持使用技術(shù)構(gòu)建移動(dòng)應(yīng)用程序的人之一。我們準(zhǔn)備做這樣的一個(gè)漸進(jìn)式應(yīng)用是典型的旨在提高用戶離線體驗(yàn)的應(yīng)用。當(dāng)我們開(kāi)始構(gòu)建應(yīng)用時(shí),你就能理解上面的場(chǎng)景了。的作用范圍是針對(duì)相對(duì)路徑的。最佳的做法是在應(yīng)用的入口。 我喜歡移動(dòng)app,而且也是那些堅(jiān)持使用Web技術(shù)構(gòu)建移動(dòng)應(yīng)用程序的人之一。 經(jīng)過(guò)技術(shù)的不斷迭代(可能還有一些其它的東西),移動(dòng)體驗(yàn)設(shè)計(jì)愈來(lái)愈平易近人,給予用戶...

    Sanchi 評(píng)論0 收藏0
  • 前端應(yīng)該知曉的PWA

    摘要:對(duì)來(lái)說(shuō)主要兩個(gè)事件。是當(dāng)前的變量,執(zhí)行該方法表示強(qiáng)制當(dāng)前處在狀態(tài)的進(jìn)入狀態(tài)。頁(yè)面關(guān)閉之后,老的會(huì)被干掉,新的接管頁(yè)面新的生效后會(huì)觸發(fā)事件。 一、傳統(tǒng)web 應(yīng)用 當(dāng)前web應(yīng)用在移動(dòng)時(shí)代并沒(méi)有達(dá)到其在桌面設(shè)備上流行的程度,下面有張圖來(lái)對(duì)比與原生應(yīng)用之間的差別。 showImg(https://segmentfault.com/img/bVbaD44?w=1920&h=1080)...

    GT 評(píng)論0 收藏0
  • [翻譯]Service workers:PWA背后的英雄

    摘要:如果返回的被拒,另一個(gè)同步事件被自動(dòng)地開(kāi)始重試操作,直到返回一個(gè)成功狀態(tài)的。推送機(jī)制使得服務(wù)器能夠向發(fā)送信息,然后將信息展示給用戶才是消息通知。然后它們可以發(fā)送消息通知,或者是更新的狀態(tài)。 原文地址:https://medium.freecodecamp.org/service-workers-the-little-heroes-behind-progressive-web-apps-...

    snifes 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<