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

資訊專欄INFORMATION COLUMN

JavaScript 是如何工作的:Service Worker 的生命周期及使用場(chǎng)景

zzzmh / 3519人閱讀

摘要:的生命周期的生命周期與頁(yè)面完全分離。換句話說(shuō),這個(gè)將為這個(gè)域中的所有內(nèi)容接收事件。這不是必要的,但絕對(duì)是推薦的。新的將啟動(dòng)并且安裝事件將被移除。使用,可以很容易被劫持連接并偽造響應(yīng)。后臺(tái)同步允許延遲操作,直到用戶具有穩(wěn)定的連接。

這是專門探索 JavaScript 及其所構(gòu)建的組件的系列文章的第8篇。

想閱讀更多優(yōu)質(zhì)文章請(qǐng)猛戳GitHub博客,一年百來(lái)篇優(yōu)質(zhì)文章等著你!

如果你錯(cuò)過(guò)了前面的章節(jié),可以在這里找到它們:

JavaScript是如何工作的:引擎,運(yùn)行時(shí)和調(diào)用堆棧的概述!

JavaScript是如何工作的:深入V8引擎&編寫優(yōu)化代碼的5個(gè)技巧!

JavaScript如何工作:內(nèi)存管理+如何處理4個(gè)常見(jiàn)的內(nèi)存泄漏 !

JavaScript是如何工作的:事件循環(huán)和異步編程的崛起+ 5種使用 async/await 更好地編碼方式!

JavaScript是如何工作: 深入探索 websocket 和HTTP/2與SSE +如何選擇正確的路徑!

JavaScript是如何工作的:與 WebAssembly比較 及其使用場(chǎng)景 !

JavaScript是如何工作的:Web Workers的構(gòu)建塊+ 5個(gè)使用他們的場(chǎng)景

你可能已經(jīng)知道,漸進(jìn)式Web應(yīng)用程序 只會(huì)越來(lái)越受歡迎,因?yàn)樗鼈兊哪繕?biāo)是讓W(xué)eb應(yīng)用程序用戶體驗(yàn)更流暢,創(chuàng)建類似于原生應(yīng)用程序的體驗(yàn),而不是瀏覽器的外觀和感覺(jué)。

構(gòu)建漸進(jìn)式Web應(yīng)用程序的主要要求之一是使其在網(wǎng)絡(luò)和加載方面非??煽俊鼞?yīng)該在不確定或不存在的網(wǎng)絡(luò)條件下可用。

在這篇文章中,將深入探討 Service Workers:它們是如何工作,你應(yīng)該關(guān)心什么。最后,還列出了 Service Workers 中的一些獨(dú)特優(yōu)點(diǎn)在哪些場(chǎng)景下是值得我們使用的。

簡(jiǎn)介

如果你還想了解更多 Service Workers 的知識(shí),可以閱讀作者關(guān)于 Web Workers 的文章。

Service Worker是什么

MDN 的介紹:

Service Worker 是一個(gè)瀏覽器背后運(yùn)行的腳步,獨(dú)立于 web 頁(yè)面,為無(wú)需一個(gè)頁(yè)面或用戶交互的功能打開(kāi)了大門。今日,它包含了推送通知和背景異步(push notifications and background sync)的功能。將來(lái),Service Worker 將支持包括 periodic sync or geofencing 的功能。

基本上,Service Worker 是 Web Worker 的一個(gè)類型,更具體地說(shuō),它像 Shared Worker:

Service Worker 在其自己的全局上下文中運(yùn)行

它沒(méi)有綁定到特定的網(wǎng)頁(yè)

它不能訪問(wèn)到 DOM

這是一個(gè)令人興奮的 API 的原因是它允許你支持離線體驗(yàn),讓開(kāi)發(fā)人員完全控制體驗(yàn)。

Service Worker 的生命周期

Service Worker 的生命周期與 web 頁(yè)面完全分離。它包括以下幾個(gè)階段:

下載

安裝

激活

下載

這是瀏覽器下載包含 Service Worker 的 .js 文件的時(shí)候。

安裝

要為 web 應(yīng)用程序安裝 Service Worker,必須先注冊(cè)它,這可以在 JavaScript 代碼中完成。注冊(cè) Service Worker 后,它會(huì)提示瀏覽器在后臺(tái)啟動(dòng) Service Worker 安裝步驟。

通過(guò)注冊(cè) Service Worker,你可以告訴瀏覽器你的 Service Worker 的 JavaScript 文件的位置??纯聪旅娴拇a:

上例代碼首先檢查當(dāng)前環(huán)境中是否支持 Service Worker API。如果支持,則 /sw.js 這個(gè) Service Worker 就被注冊(cè)了。

每次頁(yè)面加載時(shí)都可以調(diào)用 register() 方法,瀏覽器會(huì)判斷 Service Worker 是否已經(jīng)注冊(cè),根據(jù)注冊(cè)情況會(huì)對(duì)應(yīng)的給出正確處理。

register() 方法的一個(gè)重要細(xì)節(jié)是 Service Worker 文件的位置。在本例中,可以看到 Service Worker 文件位于域的根目錄,這意味著 Service Worker 范圍將是這個(gè)域下的。換句話說(shuō),這個(gè) Service Worker 將為這個(gè)域中的所有內(nèi)容接收 fetch 事件。如果我們?cè)?/example/sw.js 注冊(cè) Service Worker 文件,那么 Service Worker 只會(huì)看到以 /example/ 開(kāi)頭的頁(yè)面的 fetch 事件(例如 /example/page1/、/example/page2/)。

通常在安裝步驟中,你需要緩存一些靜態(tài)資源。 如果所有文件都緩存成功,則 Service Worker 將被安裝。 如果任何文件無(wú)法下載和緩存,則安裝步驟將失敗,Service Worker 將不會(huì)激活(即不會(huì)被安裝)。 如果發(fā)生這種情況,不要擔(dān)心,下次再試一次。 但是,這意味著如果它安裝,你知道你有這些靜態(tài)資源在緩存中。

如果注冊(cè)需要在加載事件之后發(fā)生,這就解答了你“注冊(cè)是否需要在加載事件之后發(fā)生”的疑惑。這不是必要的,但絕對(duì)是推薦的。

為什么?讓我們考慮用戶第一次訪問(wèn)你的 Web 應(yīng)用程序。目前還沒(méi)有 Service Worker,而且瀏覽器無(wú)法預(yù)先知道最終是否會(huì)安裝 Service Worker。如果安裝了 Service Worker,瀏覽器將需要為這個(gè)額外的線程花費(fèi)額外的 CPU 和內(nèi)存,否則瀏覽器將把這些額外的 CPU 和內(nèi)存用于呈現(xiàn) Web 頁(yè)面。

最重要的是,如果在頁(yè)面上安裝一個(gè) Service Worker,就可能會(huì)有延遲加載和渲染的風(fēng)險(xiǎn) —— 而不是盡快讓你的用戶可以使用該頁(yè)面。

注意,這種情況對(duì)第一次的訪問(wèn)頁(yè)面時(shí)才會(huì)有。后續(xù)的頁(yè)面訪問(wèn)不會(huì)受到 Service Worker 安裝的影響。一旦 Service Worker 在第一次訪問(wèn)頁(yè)面時(shí)被激活,它就可以處理加載/緩存事件,以便后續(xù)訪問(wèn) Web 應(yīng)用程序。這一切都是有意義的,因?yàn)樗枰獪?zhǔn)備好處理受限的的網(wǎng)絡(luò)連接。

激活

安裝 Service Worker 之后,下一步將是激活它,這是處理舊緩存管理的好機(jī)會(huì)。

在激活步驟之后,Service Worker 將控制所有屬于其范圍的頁(yè)面,盡管第一次注冊(cè) Service Worker 的頁(yè)面將不會(huì)被控制,直到再次加載。

Service Worker 一旦掌控,它將處于以下兩種狀態(tài)之一:

處理從網(wǎng)頁(yè)發(fā)出網(wǎng)絡(luò)請(qǐng)求或消息時(shí)發(fā)生的提取和消息事件

Service Worker 將被終止以節(jié)省內(nèi)存

Service Worker 生命周期如下:

Service Worker 安裝的內(nèi)部機(jī)制

在頁(yè)面啟動(dòng)注冊(cè)過(guò)程之后,看看 Service Worker 腳本中發(fā)生了什么,它通過(guò)向 Service Worker 實(shí)例添加事件監(jiān)聽(tīng)來(lái)處理 install 事件:

以下是處理安裝事件時(shí)需要采取的步驟:

開(kāi)啟一個(gè)緩存

緩存我們的文件

確認(rèn)是否緩存了所有必需的資源

對(duì)于最基本的示例,你需要為安裝事件定義回調(diào)并決定要緩存哪些文件。

self.addEventListener("install", function(event) { // Perform install steps });

下面是 Service Worker 簡(jiǎn)單的一個(gè)內(nèi)部安裝過(guò)程:

從上例代碼可以得到:

調(diào)用了caches.open() 和我們想要的緩存名稱, 之后調(diào)用 cache.addAll() 并傳入文件數(shù)組。 這是一個(gè)promise 鏈( caches.open() 和 cache.addAll() )。 event.waitUntil() 方法接受一個(gè)承諾,并使用它來(lái)知道安裝需要多長(zhǎng)時(shí)間,以及它是否成功。

如果成功緩存了所有文件,那么將安裝 Service Worker。如果其中的一個(gè)文件下載失敗,那么安裝步驟將失敗。這意味著需要小心在安裝步驟中決定要緩存的文件列表,定義一長(zhǎng)串文件將增加一個(gè)文件可能無(wú)法緩存的機(jī)會(huì),導(dǎo)致你的 Service Worker 沒(méi)有得到安裝。

處理 install 事件完全是可選的,你可以避免它,在這種情況下,你不需要執(zhí)行這里的任何步驟。

運(yùn)行時(shí)緩存請(qǐng)求

安裝了 Service Worker 后,用戶導(dǎo)航到另一個(gè)頁(yè)面或刷新所在的頁(yè)面,Service Worker 將收到 fetch 事件。下面是一個(gè)例子,演示如何返回緩存的資源或執(zhí)行一個(gè)新的請(qǐng)求,然后緩存結(jié)果:

上述流程:

在這里我們定義了 fetch 事件,在 event.respondWith() 中,我們傳遞了一個(gè)來(lái)自 caches.match()promise。 此方法查看請(qǐng)求,并查找來(lái)自 Service Worker 創(chuàng)建的任何緩存的任何緩存結(jié)果。

如果在緩存中,響應(yīng)內(nèi)容就被恢復(fù)了。

否則,將會(huì)執(zhí)行 fetch。

檢查狀態(tài)碼是不是 200,同時(shí)檢查響應(yīng)類型是 basic,表明響應(yīng)來(lái)自我們最初的請(qǐng)求。在這種情況下,不會(huì)緩存對(duì)第三方資源的請(qǐng)求。

響應(yīng)被緩存下來(lái)

如果通過(guò)檢查,克隆響應(yīng)。這是因?yàn)轫憫?yīng)是 Stream,所以只能消耗一次。既然要返回瀏覽器使用的響應(yīng),并將其傳遞給緩存使用,就需要克隆它,以便可以一個(gè)發(fā)送到瀏覽器,一個(gè)發(fā)送到緩存。

更新 Service Worker

當(dāng)用戶訪問(wèn)你的 Web 應(yīng)用程序時(shí),瀏覽器試圖重新下載包含 Service Worker 代碼的 .js 文件,這是在后臺(tái)完成的。

如果現(xiàn)在下載的 Service Worker 的文件與當(dāng)前 Service Worker 的文件相比如果有一個(gè)字節(jié)及以上的差異,瀏覽器將假設(shè) Service Worker 文件已改過(guò),瀏覽器就會(huì)啟動(dòng)新的 Service Worker。

新的 Service Worker 將啟動(dòng)并且安裝事件將被移除。然而,在這一點(diǎn)上,舊的 Service Worker 仍在控制你的 web 應(yīng)用的頁(yè)面,這意味著新的 Service Worker 將進(jìn)入 waiting 狀態(tài)。

一旦你的 Web 應(yīng)用程序當(dāng)前打開(kāi)的頁(yè)面被關(guān)閉,舊的 Service Worker 將被瀏覽器殺死,新 Service Worker 接管了控制權(quán),它的激活事件將被激發(fā)

為什么需要這些?為了避免 Web 應(yīng)用程序的兩個(gè)版本同時(shí)在不同的 tab 上運(yùn)行的問(wèn)題——這在 Web 上是非常常見(jiàn)的,并且可能會(huì)產(chǎn)生非常嚴(yán)重的bug(例如,在瀏覽器中本地存儲(chǔ)數(shù)據(jù)時(shí)使用不同的模式)。

從緩存中刪除數(shù)據(jù)

在激活回調(diào)中發(fā)生的一個(gè)常見(jiàn)任務(wù)是緩存管理。你要在激活回調(diào)中這樣做的原因是,如果你要在安裝步驟中清除所有舊的緩存,任何保留所有當(dāng)前頁(yè)面的舊 Service Worker 將會(huì)突然停止服務(wù)來(lái)自該緩存的文件。

這里提供了一個(gè)如何從緩存中刪除一些不在白名單中的文件的例子(在本例中,有 page-1、page-2 兩個(gè)實(shí)體):

要求 HTTPS 的原因

在構(gòu)建 Web 應(yīng)用程序時(shí),通過(guò) localhost 使用 Service Workers,但是一旦將其部署到生產(chǎn)環(huán)境中,就需要準(zhǔn)備好 HTTPS( 這是使用HTTPS 的最后一個(gè)原因)。

使用 Service Worker,可以很容易被劫持連接并偽造響應(yīng)。如果不使用 HTTPs,人的web應(yīng)用程序就容易受到黑客的攻擊。

為了更安全,你需要在通過(guò) HTTPS 提供的頁(yè)面上注冊(cè) Service Worker,以便知道瀏覽器接收的 Service Worker 在通過(guò)網(wǎng)絡(luò)傳輸時(shí)未被修改。

瀏覽器支持

瀏覽器對(duì) Service Worker 的支持正在變得越來(lái)越好:

Service Workers 特性將越來(lái)越完善及強(qiáng)大

Service Workers 提供的一些獨(dú)特特性包括:

推送通知 —?允許用戶選擇從網(wǎng)絡(luò)應(yīng)用程序及時(shí)更新。

后臺(tái)同步 — 允許延遲操作,直到用戶具有穩(wěn)定的連接。通過(guò)這種方式,可以確保用戶想發(fā)送的任何內(nèi)容實(shí)都可以發(fā)送。

定期同步(后續(xù)開(kāi)放) — 提供管理定期后臺(tái)同步功能的 API。

Geofencing (后續(xù)開(kāi)放) — 可以定義參數(shù),也稱為圍繞感興趣領(lǐng)域的 geofences。當(dāng)設(shè)備通過(guò)geofence 時(shí),Web 應(yīng)用程序會(huì)收到一個(gè)通知,該通知允許根據(jù)用戶的地理位置提供更好的體驗(yàn)。

原文:

https://blog.sessionstack.com...

代碼部署后可能存在的BUG沒(méi)法實(shí)時(shí)知道,事后為了解決這些BUG,花了大量的時(shí)間進(jìn)行l(wèi)og 調(diào)試,這邊順便給大家推薦一個(gè)好用的BUG監(jiān)控工具 Fundebug。

你的點(diǎn)贊是我持續(xù)分享好東西的動(dòng)力,歡迎點(diǎn)贊!

歡迎加入前端大家庭,里面會(huì)經(jīng)常分享一些技術(shù)資源。

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

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

相關(guān)文章

  • JavaScript 工作原理之八-Service Workers,生命周期使用場(chǎng)景

    摘要:生命周期的生命周期和網(wǎng)頁(yè)完全不相關(guān)。意即會(huì)作用于整個(gè)源地址上。激活安裝完之后下一步即激活。同時(shí)檢查響應(yīng)類型是否為,即檢查請(qǐng)求是否同域。創(chuàng)建新的的過(guò)程將會(huì)啟動(dòng),然后觸發(fā)事件??梢岳媒俪志W(wǎng)絡(luò)連接和偽造響應(yīng)數(shù)據(jù)。 原文請(qǐng)查閱這里,略有刪減,本文采用知識(shí)共享署名 4.0 國(guó)際許可協(xié)議共享,BY Troland。 本系列持續(xù)更新中,Github 地址請(qǐng)查閱這里。 這是 JavaScript 工...

    oysun 評(píng)論0 收藏0
  • JavaScript如何工作:Web推送通知機(jī)制

    摘要:在端,盡管開(kāi)發(fā)人員對(duì)其功能的需求很高,但出于某些原因,推送通知被引入的時(shí)間比較晚。發(fā)送推送通知在服務(wù)器上實(shí)現(xiàn)調(diào)用,該調(diào)用觸發(fā)到用戶設(shè)備的推送消息。推送服務(wù)推送服務(wù)是接收請(qǐng)求驗(yàn)證請(qǐng)求并將推送消息發(fā)送到對(duì)應(yīng)的瀏覽器。 這是專門探索 JavaScript 及其所構(gòu)建的組件的系列文章的第9篇。 想閱讀更多優(yōu)質(zhì)文章請(qǐng)猛戳GitHub博客,一年百來(lái)篇優(yōu)質(zhì)文章等著你! 如果你錯(cuò)過(guò)了前面的章節(jié),可以在...

    KitorinZero 評(píng)論0 收藏0
  • JavaScript工作原理(八):Service Workers,生命周期和應(yīng)用案例

    摘要:的生命周期生命周期與您的網(wǎng)頁(yè)是完全分開(kāi)。激活安裝之后,下一步是將其激活。一旦激活,將開(kāi)始控制所有屬于其范圍的頁(yè)面。否則,將執(zhí)行事件。響應(yīng)結(jié)果被添加到緩存中。請(qǐng)求和響應(yīng)必須被克隆,因?yàn)樗鼈兪橇?。新的將啟?dòng)并且事件將被觸發(fā)。 showImg(https://segmentfault.com/img/bV9Sa2?w=800&h=410);您可能已經(jīng)知道,漸進(jìn)式Web應(yīng)用(PWA)會(huì)越來(lái)越受...

    huaixiaoz 評(píng)論0 收藏0
  • 構(gòu)建 Web 應(yīng)用之 Service Worker 初探

    摘要:誕生之初,是單線程的。當(dāng)接收到服務(wù)端的響應(yīng)之后,便通過(guò)回調(diào)函數(shù)執(zhí)行之后的操作。沖鋒基于事件驅(qū)動(dòng)。擁有攔截請(qǐng)求消息推送靜默更新地理圍欄等服務(wù)??刂茣r(shí)處于兩種狀態(tài)之一終止以節(jié)省內(nèi)存監(jiān)聽(tīng)獲取和消息事件。支持的所有事件五銷毀瀏覽器決定是否銷毀。 這次體驗(yàn)一種新的博客風(fēng)格,我們長(zhǎng)話短說(shuō),針針見(jiàn)血。 showImg(https://segmentfault.com/img/remote/14600...

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

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

0條評(píng)論

zzzmh

|高級(jí)講師

TA的文章

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