vue項目發(fā)布有緩存正式環(huán)境不更新的解決方案
前言:每次測試構(gòu)建或者打包更新版本發(fā)到服務(wù)器上,導(dǎo)致偶爾會出現(xiàn)不能及時更新到最新代碼,瀏覽器存在緩存的問題。
一、js、css文件防緩存
定義版本變量: const Version = new Date().getTime(); // 這里使用的是時間戳 來區(qū)分 ,實際上不用加時間戳,webpack內(nèi)部還自動變化hash值
output: { path: config.build.assetsRoot, filename: utils.assetsPath('js/[name].[chunkhash].'+_Version+'js'), chunkFilename: utils.assetsPath('js/[id].[chunkhash].'+_Version+'js') }
二、html文件防緩存
方法1、Linux服務(wù)器設(shè)置nginx禁用html緩存
在開發(fā)調(diào)試web的時候,經(jīng)常會碰到因瀏覽器緩存(cache)而經(jīng)常要去清空緩存或者強制刷新來測試的煩惱,提供下apache不緩存配置和nginx不緩存配置的設(shè)置。在常用的緩存設(shè)置里面有兩種方式,都是使用add_header來設(shè)置:分別為Cache-Control和Pragma。
add_header Cache-Control no-store;
add_header Pragma no-cache;
server { listen 80; server_name test.exmaple.cn; location / { if ($request_filename ~* .*\.(?:htm|html)$) ## 配置頁面不緩存html和htm結(jié)尾的文件 { add_header Cache-Control "private, no-store, no-cache, must-revalidate, proxy-revalidate"; } root /web/; index index.html; try_files $uri $uri/ /index.html =404; } }
方法2、index.html頁面添加
<meta http-equiv="Expires" content="0"> <meta http-equiv="Pragma" content="no-cache"> <meta http-equiv="Cache-control" content="no-cache"> <meta http-equiv="Cache" content="no-cache">
方法3、(Vue-cli前端代碼控制)
1.在public靜態(tài)目錄下新建version.json每次發(fā)版更改里面的版本號
{ "version": "0.0.1" }
2.在src中新建 libs/versionUpdate.js文件
import axios from 'axios' const isNewVersion = () => { let url = `//${window.location.host}/version.json?t=${new Date().getTime()}` axios.get(url).then(res => { if (res.status === 200) { let vueVersion = res.data.version || '1.0.0' let localVueVersion = localStorage.getItem('vueVersion') localStorage.setItem('vueVersion', vueVersion) if (localVueVersion && localVueVersion != vueVersion) { alert('檢測到新版本,請點擊確認(rèn)刷新頁面哦') window.location.reload(true) return } } }) } export default { isNewVersion }
3.在全局路由攔截中寫,只要每次版本號不同就重新加載頁面配合第一步就可以清楚瀏覽器緩存
import versionTood from '@/libs/versionUpdate' router.beforeEach(( to, from, next ) => { //判斷當(dāng)前代碼版本是否與服務(wù)器中代碼版本一致,如不一致則刷新頁面獲取最新 versionTood.isNewVersion(); }
總結(jié)
到此這篇關(guān)于vue項目發(fā)布有緩存正式環(huán)境不更新的解決方案的文章就介紹到這了,更多相關(guān)vue項目發(fā)布有緩存解決內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Vue3實現(xiàn)一個簡單的思維導(dǎo)圖組件
思維導(dǎo)圖是一種用于表示信息、想法和概念的圖形化工具,本文將基于 Vue3和VueDraggable實現(xiàn)一個簡單的思維導(dǎo)圖組件,支持節(jié)點拖拽,編輯及節(jié)點之間的關(guān)系連接,希望對大家有所幫助2025-04-04Vue 實時監(jiān)聽窗口變化 windowresize的兩種方法
這篇文章主要介紹了Vue 實時監(jiān)聽窗口變化 windowresize的兩種方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-11-11vue修改數(shù)據(jù)視圖更新原理學(xué)習(xí)
這篇文章主要為大家介紹了vue修改數(shù)據(jù)視圖更新原理學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11