亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue 打包上線后的緩存問題解決

 更新時間:2023年11月29日 16:53:38   作者:樂辭  
在使用vue腳手架搭建前端工程時,經(jīng)常會遇到打包上線后的緩存問題,許多開發(fā)者會直接在index.html中加入類似以下代碼來解決緩存問題,本文通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧

問題描述

在使用vue腳手架搭建前端工程時,經(jīng)常會遇到打包上線后的緩存問題。具體表現(xiàn)為,當程序版本升級時,用戶仍然訪問到舊版本的頁面。許多開發(fā)者會直接在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">

這種方法雖然解決了緩存問題,但卻導致用戶每次訪問程序都需要重新請求服務器,無法利用靜態(tài)資源的緩存,從而增加了流量消耗和網(wǎng)絡壓力。

需求澄清

實際上,我們需要解決的問題并不是簡單地要緩存或不要緩存,而是希望根據(jù)情況靈活控制

  • 每次程序升級后,用戶不會因為緩存問題而訪問到舊版本的程序。
  • 如果程序沒有升級,用戶可以利用靜態(tài)資源的緩存,減少對服務器的請求。

解決原理

在vue腳手架的每次打包過程中,會給生成的靜態(tài)資源文件名添加哈希后綴,并 index.html中引入帶有相應哈希后綴的靜態(tài)資源文件。因此,每個版本的靜態(tài)資源都是被正確引入的,不會因升級而出現(xiàn)緩存問題。因此,我們只需讓index.html不被緩存,而讓其他靜態(tài)資源可以被緩存,即可滿足需求。

然而,要實現(xiàn)讓靜態(tài)資源被緩存,但讓index.html不被緩存,則需要借助服務器配置,通過設置針對index.html請求的header來控制緩存。

具體實現(xiàn)

Nginx服務器配置

如果你使用Nginx服務器,你可以簡單地添加以下配置:

location = /index.html {
 add_header Cache-Control "no-cache, no-store";
}

Apache服務器配置

如果你使用Apache服務器,你可以在VirtualHost中增加以下配置:

<Files "index.html">  
    Header set Cache-Control "no-cache, no-store"  
 </Files>

修改webpack的配置文件

同時,你也可以通過修改webpack的配置文件來實現(xiàn)對靜態(tài)資源文件名的哈希處理,以確保靜態(tài)資源能夠被有效緩存:

 onst Timestamp = new Date().getTime();
 // Vue.config.js 配置選項
module.exports = {
	configureWebpack: { // webpack 配置
        output: { // 輸出重構  打包編譯后的 文件名稱:【模塊名稱.contenthash】使用contenthash保證了文件被修改才會重新生成新的文件名,讓用戶能有效使用瀏覽器緩存,減輕服務器壓力
            filename: `static/js/[name].[contenthash:8].js`,
            chunkFilename: `static/js/[name].[contenthash:8].js`
        },
    }
}

通過以上步驟,你可以靈活地控制緩存,讓用戶在程序升級后訪問到最新版本的頁面,同時減少了靜態(tài)資源的重復請求,優(yōu)化了用戶體驗和網(wǎng)絡流量消耗。

到此這篇關于Vue 打包上線后的緩存問題的文章就介紹到這了,更多相關vue打包上線緩存內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue中的v-for列表循環(huán)示例詳解

    Vue中的v-for列表循環(huán)示例詳解

    循環(huán)使用v-for指令,v-for指令需要以site in sites形式的特殊語法,sites是源數(shù)據(jù)數(shù)組并且site是數(shù)組元素迭代的別名,下面這篇文章主要給大家介紹了關于Vue中v-for列表循環(huán)的相關資料,需要的朋友可以參考下
    2022-11-11
  • Vue學習筆記進階篇之vue-cli安裝及介紹

    Vue學習筆記進階篇之vue-cli安裝及介紹

    這篇文章主要介紹了Vue學習筆記進階篇之vue-cli安裝及介紹,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • vue中checkbox如何修改為圓形樣式

    vue中checkbox如何修改為圓形樣式

    這篇文章主要介紹了vue中checkbox如何修改為圓形樣式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Vue 2.0的數(shù)據(jù)依賴實現(xiàn)原理代碼簡析

    Vue 2.0的數(shù)據(jù)依賴實現(xiàn)原理代碼簡析

    本篇文章主要介紹了Vue 2.0的數(shù)據(jù)依賴實現(xiàn)原理代碼簡析,主要從初始化的數(shù)據(jù)層面上分析了Vue是如何管理依賴來到達數(shù)據(jù)的動態(tài)響應,有興趣的可以了解一下
    2017-07-07
  • vue靜態(tài)配置文件不進行編譯的處理過程(在public中引入js)

    vue靜態(tài)配置文件不進行編譯的處理過程(在public中引入js)

    這篇文章主要介紹了vue靜態(tài)配置文件不進行編譯的處理過程(在public中引入js),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • vue中el-table合并列的具體實現(xiàn)

    vue中el-table合并列的具體實現(xiàn)

    本文主要介紹了vue中el-table合并列的具體實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • element中el-table局部刷新的實現(xiàn)示例

    element中el-table局部刷新的實現(xiàn)示例

    本文主要介紹了element中el-table局部刷新的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • 詳解Unity webgl 嵌入Vue實現(xiàn)過程

    詳解Unity webgl 嵌入Vue實現(xiàn)過程

    Unity webgl嵌入到前端網(wǎng)頁中,前端通過調用Unity webgl內方法實現(xiàn)需要展示的功能,前端點擊Unity webgl內的交互點,Unity webgl返回給前端一些需要的數(shù)據(jù),這篇文章主要介紹了Unity webgl 嵌入Vue實現(xiàn)過程,需要的朋友可以參考下
    2024-01-01
  • vue如何獲取參數(shù)方法的封裝

    vue如何獲取參數(shù)方法的封裝

    文章介紹了如何在Vue.js中獲取URL參數(shù)、定義和暴露公共方法、在main.js中引入并注冊到Vue實例原型,以及頁面中調用這些方法,作者分享了個人經(jīng)驗,希望對大家有所幫助
    2024-12-12
  • Vue開發(fā)中遇到的跨域問題及解決方法

    Vue開發(fā)中遇到的跨域問題及解決方法

    在本篇文章里小編給大家整理的是關于Vue開發(fā)中遇到的跨域問題及解決方法,需要的朋友們可以學習下。
    2020-02-02

最新評論