本文作者:薛定喵君
原文地址: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