使用offline-plugin配置service-worker的問題

最近有需求要求頁面離線緩存悟狱,所以使用了service-worker钥庇,找了很多資料媚狰,最后選擇了webpack插件offline-plugin

參考了使用offline-plugin搭配webpack輕松實現(xiàn)PWA中的配置憋沿,但是還是遇到了很多問題勿璃,在這里記錄一下

1. vue-cli3的問題

剛開始配置簡單,發(fā)現(xiàn)狀態(tài)改變時并沒有觸發(fā)對應的事件,于是增加了配置項

vuecli3的webpack配置在vue.config中,具體配置如下

這里直接將sw文件輸出到根路徑榛臼,并且開啟了改變狀態(tài)時觸發(fā)對應的事件

module.exports = {
  configureWebpack: {
    plugins: [
      new OfflinePlugin(
        {
          responseStrategy: 'cache-first', // 緩存優(yōu)先
          AppCache: false, // 不啟用appCache
          safeToUseOptionalCaches: true, // Removes warning for about `additional` section usage
          ServiceWorker: {
            output: './sw.js', // 輸出目錄
            publicPath: './sw.js', // sw.js 加載路徑
            scope: '/', // 作用域
            minify: true, // 開啟壓縮
            events: true // 當sw狀態(tài)改變時候發(fā)射對應事件
          },
          caches: 'all',
          autoUpdate: 30000
        }
      )
    ]
  }
}

更多配置內(nèi)容請查閱https://github.com/NekR/offline-plugin/blob/master/docs/options.md

2. 事件觸發(fā)

在這里希望得到的情況是,當檢測到sw文件改變(代碼發(fā)生更新變化)時窜司,通過一個鉤子函數(shù)來更新一下當前頁面(例如: 彈出一個對話框詢問發(fā)現(xiàn)更新的內(nèi)容沛善,提示是否立即更新)

在main.js中注冊

當頁面更新時, 將會觸發(fā)如下幾個鉤子函數(shù),使用OfflinePluginRuntime.applyUpdate()可以直接更新

import * as OfflinePluginRuntime from 'offline-plugin/runtime'

OfflinePluginRuntime.install({
  onUpdateReady: () => {
    console.log('SW Event:', 'onUpdateReady')
    OfflinePluginRuntime.applyUpdate()
  },
  onUpdated: () => {
    console.log('SW Event:', 'onUpdated')
    // Reload the webpage to load into the new version
    window.swUpdate = true
  }
})

更多options請訪問

3 more

更多資料查閱

https://developer.mozilla.org/zh-CN/docs/Web/API/Service_Worker_API

https://x5.tencent.com/tbs/guide/serviceworker.html

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末塞祈,一起剝皮案震驚了整個濱河市金刁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖尤蛮,帶你破解...
    沈念sama閱讀 219,589評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件媳友,死亡現(xiàn)場離奇詭異,居然都是意外死亡产捞,警方通過查閱死者的電腦和手機醇锚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,615評論 3 396
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來坯临,“玉大人焊唬,你說我怎么就攤上這事】纯浚” “怎么了赶促?”我有些...
    開封第一講書人閱讀 165,933評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長衷笋。 經(jīng)常有香客問我芳杏,道長矩屁,這世上最難降的妖魔是什么辟宗? 我笑而不...
    開封第一講書人閱讀 58,976評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮吝秕,結果婚禮上泊脐,老公的妹妹穿的比我還像新娘。我一直安慰自己烁峭,他們只是感情好容客,可當我...
    茶點故事閱讀 67,999評論 6 393
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著约郁,像睡著了一般缩挑。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上鬓梅,一...
    開封第一講書人閱讀 51,775評論 1 307
  • 那天供置,我揣著相機與錄音,去河邊找鬼绽快。 笑死芥丧,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的坊罢。 我是一名探鬼主播续担,決...
    沈念sama閱讀 40,474評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼活孩!你這毒婦竟也來了物遇?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,359評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎挎挖,沒想到半個月后这敬,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,854評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡蕉朵,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,007評論 3 338
  • 正文 我和宋清朗相戀三年崔涂,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片始衅。...
    茶點故事閱讀 40,146評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡冷蚂,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出汛闸,到底是詐尸還是另有隱情蝙茶,我是刑警寧澤,帶...
    沈念sama閱讀 35,826評論 5 346
  • 正文 年R本政府宣布诸老,位于F島的核電站隆夯,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏别伏。R本人自食惡果不足惜蹄衷,卻給世界環(huán)境...
    茶點故事閱讀 41,484評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望厘肮。 院中可真熱鬧愧口,春花似錦、人聲如沸类茂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,029評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽巩检。三九已至厚骗,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間兢哭,已是汗流浹背领舰。 一陣腳步聲響...
    開封第一講書人閱讀 33,153評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留厦瓢,地道東北人提揍。 一個月前我還...
    沈念sama閱讀 48,420評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像煮仇,于是被迫代替她去往敵國和親劳跃。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,107評論 2 356

推薦閱讀更多精彩內(nèi)容