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

webpack+express實現文件精確緩存的示例代碼

 更新時間:2020年06月11日 09:31:33   作者:woai3c  
這篇文章主要介紹了webpack+express實現文件精確緩存的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

由于最近開發(fā)的個人博客(Vue + node)在使用過程中,發(fā)現網絡加載有點慢,所以打算對它進行一次優(yōu)化。本次優(yōu)化的目標如下:

  • index.html 設置成 no-cache,這樣每次請求的時候都會比對一下 index.html 文件有沒變化,如果沒變化就使用緩存,有變化就使用新的 index.html 文件。
  • 其他所有文件一律使用長緩存,例如設置成緩存一年 maxAge: 1000 * 60 * 60 * 24 * 365。
  • 前端代碼使用 webpack 打包,根據文件內容生成對應的文件名,每次重新打包時只有內容發(fā)生了變化,文件名才會發(fā)生變化。

以上三點結合,就能實現文件的精確緩存。

換句話說,在一年內,如果我的個人博客沒有進行任何更新,那同一臺電腦在這段時間內訪問網站不會發(fā)起任何請求;如果有某個文件更新了,只會請求新的文件,舊的文件依舊從緩存讀取。

小知識:

  • max-age: 設置緩存存儲的最大周期,超過這個時間緩存被認為過期(單位秒)。在這個時間前,瀏覽器讀取文件不會發(fā)出新請求,而是直接使用緩存。
  • 指定 no-cache 表示客戶端可以緩存資源,每次使用緩存資源前都必須重新驗證其有效性。

webpack 打包

根據文件內容生成文件名

通過配置 output 的 filename 屬性可以實現這個需求。filename 屬性的值選項中有一個 [contenthash],它將根據文件內容創(chuàng)建出唯一 hash。當文件內容發(fā)生變化時,[contenthash] 也會發(fā)生變化。

output: {
 filename: '[name].[contenthash].js',
 chunkFilename: '[name].[contenthash].js',
 path: path.resolve(__dirname, '../dist'),
},

提取第三方庫

由于引入的第三方庫一般都比較穩(wěn)定,不會經常改變。所以將它們單獨提取出來,作為長期緩存是一個更好的選擇。
這里需要使用 webpack4 的 splitChunk 插件 cacheGroups 選項。

optimization: {
  runtimeChunk: {
  name: 'manifest' // 將 webpack 的 runtime 代碼拆分為一個單獨的 chunk。
 },
 splitChunks: {
  cacheGroups: {
   vendor: {
    name: 'chunk-vendors',
    test: /[\\/]node_modules[\\/]/,
    priority: -10,
    chunks: 'initial'
   },
   common: {
    name: 'chunk-common',
    minChunks: 2,
    priority: -20,
    chunks: 'initial',
    reuseExistingChunk: true
   }
  },
 }
},
  • test: 用于控制哪些模塊被這個緩存組匹配到。原封不動傳遞出去的話,它默認會選擇所有的模塊??梢詡鬟f的值類型:RegExp、String和Function;
  • priority:表示抽取權重,數字越大表示優(yōu)先級越高。因為一個 module 可能會滿足多個 cacheGroups 的條件,那么抽取到哪個就由權重最高的說了算;
  • reuseExistingChunk:表示是否使用已有的 chunk,如果為 true 則表示如果當前的 chunk 包含的模塊已經被抽取出去了,那么將不會重新生成新的。
  • minChunks(默認是1):在分割之前,這個代碼塊最小應該被引用的次數(譯注:保證代碼塊復用性,默認配置的策略是不需要多次引用也可以被分割)
  • chunks (默認是async) :initial、async和all
  • name(打包的chunks的名字):字符串或者函數(函數可以根據條件自定義名字)

除了提取第三方庫外,結合 Vue 使用 import 動態(tài)引入組件還能實現按需加載。

express 設置

app.use((req, res, next) => { // 將 index.html 設為 no-cache
  if(req.url == '/') {
   res.setHeader('Cache-control', 'no-cache')
  }

  next()
 })

 app.use(express.static('dist', {
  etag: false,
  maxAge: 1000 * 60 * 60 * 24 * 365, // 緩存一年
 })) // 將dist設為根目錄

詳細的代碼可以看一下我的個人博客項目。

參考資料

webpack 緩存
一步一步的了解webpack4的splitChunk插件

到此這篇關于webpack+express實現文件精確緩存的示例代碼的文章就介紹到這了,更多相關webpack+express文件精確緩存內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • js實現手機web圖片左右滑動效果

    js實現手機web圖片左右滑動效果

    這篇文章主要為大家詳細介紹了js實現手機web圖片左右滑動效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • JS去除重復并統(tǒng)計數量的實現方法

    JS去除重復并統(tǒng)計數量的實現方法

    js去除重復并統(tǒng)計數量方法,首先點擊按鈕觸發(fā)事件,然后用class選擇器,迭代要獲取的文本(這里最好用text()方法)加入到Array()集合里。具體操作方法,大家通過本文學習下吧
    2016-12-12
  • JavaScript canvas繪制折線圖

    JavaScript canvas繪制折線圖

    這篇文章主要為大家詳細介紹了JavaScript canvas繪制折線圖,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • js判斷IE瀏覽器版本過低示例代碼

    js判斷IE瀏覽器版本過低示例代碼

    弄了個很簡單的例子判斷IE瀏覽器版本是否過低,注意在IE6和IE7版本較低情況下下才看到它的提示效果,需要的朋友可以收藏下
    2013-11-11
  • 用JS實現網頁元素陰影效果的研究總結

    用JS實現網頁元素陰影效果的研究總結

    用JS實現網頁元素陰影效果的研究總結...
    2007-08-08
  • Bootstrap網頁布局網格的實現

    Bootstrap網頁布局網格的實現

    柵格就是網格,本文詳細的介紹了Bootstrap網頁布局網格的原理和實現,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • JavaScript模擬文件拖選框樣式v1.0的實例

    JavaScript模擬文件拖選框樣式v1.0的實例

    下面小編就為大家?guī)硪黄狫avaScript模擬文件拖選框樣式v1.0的實例。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • JS簡單實現DIV相對于瀏覽器固定位置不變的方法

    JS簡單實現DIV相對于瀏覽器固定位置不變的方法

    這篇文章主要介紹了JS簡單實現DIV相對于瀏覽器固定位置不變的方法,涉及javascript針對頁面位置的運算與動態(tài)變換技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2016-06-06
  • JS判斷微信掃碼的方法

    JS判斷微信掃碼的方法

    這篇文章通過代碼給大家介紹了JS判斷是否是微信掃碼的方法,非常不錯,需要的朋友參考下吧
    2017-08-08
  • JS庫之Particles.js中文開發(fā)手冊及參數詳解

    JS庫之Particles.js中文開發(fā)手冊及參數詳解

    因為自己需要做產品,所以一個好的UI界面也是很重要的,發(fā)現這種散射的原子顆粒特效還不錯。今天腳本之家小編把Particles.js中文開發(fā)手冊及particles.js參數分享給大家,需要的朋友參考下吧
    2017-09-09

最新評論