當(dāng)前位置:首頁(yè) > IT技術(shù) > 微信平臺(tái) > 正文

uni-app開(kāi)發(fā)微信公眾號(hào)H5時(shí)防止頁(yè)面被緩存的處理
2021-10-27 14:34:29

本文作者:薛定喵君
原文地址:http://xuedingmiao.com/blog/uniapp_avoid_cache.html

背景

修改頁(yè)面后重新打包,測(cè)試人員在確認(rèn)問(wèn)題時(shí)總是說(shuō)沒(méi)改,頁(yè)面沒(méi)有變化,需要進(jìn)行繁瑣的清緩存操作才能獲取到最新版本。

解決方法

確定需要修改的文件,首先我們要看 src/manifest.json 里面定義的 template 字段,根據(jù)值找到模板文件。

例如: public/index.html

緩存的文件主要是css和js兩種,所以我們要分別處理。

樣式緩存處理

我們只需要修改模板文件中引用css的地方,在引用css文件名的前面加入哈希。類(lèi)似下面這種方式:

<link rel="stylesheet" href="<%= BASE_URL %>static/index.<%= VUE_APP_INDEX_CSS_HASH %>.css" />

如果已經(jīng)自帶了這個(gè)哈希值則不用做這個(gè)處理。

JS緩存處理

修改入口頁(yè)面的js引用機(jī)制,加入時(shí)間戳。

具體要在項(xiàng)目根目錄下添加一個(gè)vue.config.js配置,需要你的APP是命令行創(chuàng)建的,這樣在服務(wù)器上打包的時(shí)候才可以加載使用。

然后輸入如下內(nèi)容:

if (process.env.UNI_PLATFORM === 'h5') {
    let filePath = 'static/js/'
    let Timestamp = new Date().getTime()
    module.exports = {
        // webpack配置
        filenameHashing: false,
        configureWebpack: { // webpack 配置 解決js緩存的問(wèn)題
            output: { // 輸出重構(gòu)  打包編譯后的 文件目錄/文件名稱(chēng)?v=時(shí)間戳
                filename: `${filePath}[name].js?v=${Timestamp}`,
                chunkFilename: `${filePath}[name].js?v=${Timestamp}`
            },
        }
    }
} else {
    // 其他打包配置
    module.exports = {
        // webpack 相關(guān)配置
        filenameHashing: false
    }
}

這樣在打包的時(shí)候就會(huì)在引用的頁(yè)面js后面跟上版本,從而使微信瀏覽器在每次發(fā)布后都加載新的頁(yè)面js保證最新。

參考資料

本文摘自 :https://blog.51cto.com/x

開(kāi)通會(huì)員,享受整站包年服務(wù)立即開(kāi)通 >