自動獲取新版本 js 靜態文件

場景

代碼里有靜態js文件,發布一個版本1.0在真實環境,再修改重新發布2.0,用戶如何得到新版本?

方法

一、文件名哈希策略(最推薦)
通過構建工具為文件生成唯一哈希值,使每次更新后的文件名不同。瀏覽器會將新文件視為獨立資源,自動請求最新版本:

  1. 實現方式:

    // Webpack配置示例(output部分)
    output: {filename: 'main.[contenthash:8].js'
    }
    

    ? 使用contenthash根據文件內容生成哈希,內容不變時哈希值不變,最大化利用緩存。

  2. 優勢:
    ? 用戶無感知自動更新:舊版本文件仍保留在服務器,新版本通過新哈希文件名觸發請求。

    ? 緩存利用率高:未修改的資源保持長期緩存(如設置Cache-Control: max-age=31536000)。

二、URL參數版本控制
在引用JS文件時添加動態版本號或時間戳參數:

<script src="main.js?v=2.0"></script>
<!-- 或 -->
<script src="main.js?t=20250521"></script>

? 適用場景:小型項目快速迭代,無需復雜構建工具。

? 注意:需手動更新版本號,且部分瀏覽器可能緩存帶參數的URL(需配合Cache-Control: no-cache頭)。

三、服務端緩存策略優化
通過HTTP響應頭控制緩存行為:

# Nginx配置示例(強緩存+哈希策略)
location /static/ {add_header Cache-Control "public, max-age=31536000, immutable";
}

? immutable屬性:明確告知瀏覽器文件內容永久不變,避免重復驗證(需配合哈希文件名使用)。

? 協商緩存補充:對無哈希的普通文件使用ETagLast-Modified頭,確保內容變化后觸發更新。

四、用戶端輔助更新策略

  1. 版本檢測提示:
    // 前端版本檢測邏輯(示例)
    const currentVersion = '2.0';
    if (localStorage.lastVersion !== currentVersion) {localStorage.lastVersion = currentVersion;window.location.reload(true); // 強制刷新
    }
    
  2. 教育用戶操作:
    ? 告知用戶使用Ctrl+F5(Windows)或Cmd+Shift+R(Mac)強制刷新頁面。

總結流程建議(推薦方案)

  1. 開發階段:使用Webpack等工具配置contenthash文件名。

  2. 部署階段:
    ? 新版文件部署到服務器(非覆蓋舊版)

    ? 配置Cache-Control: immutable響應頭

  3. 用戶訪問:
    ? 自動加載帶新哈希的文件,舊用戶逐步過渡到新版本

    ? 未更新的用戶仍可使用舊版文件,避免功能中斷

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/80839.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/80839.shtml
英文地址,請注明出處:http://en.pswp.cn/web/80839.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

第13天-用BeautifulSoup解析網頁數據:以百度熱搜可視化為例

一、BeautifulSoup簡介 BeautifulSoup是Python最受歡迎的HTML/XML解析庫之一,它能將復雜的網頁文檔轉換為樹形結構,支持多種解析器(如lxml、html.parser)。配合requests庫,可以快速構建網頁爬蟲項目。 二、環境準備 pip install requests beautifulsoup4 matplotlib 三…

PyTorch中cdist和sum函數使用詳解

torch.cdist 是 PyTorch 中用于計算**兩個張量之間的成對距離&#xff08;pairwise distance&#xff09;**的函數&#xff0c;常用于點云處理、圖神經網絡、相似性度量等場景。 基本語法 torch.cdist(x1, x2, p2.0)參數說明&#xff1a; 參數說明x1一個形狀為 [B, M, D] 或 …

智能視覺檢測技術:制造業質量管控的“隱形守護者”

在工業4.0浪潮的推動下&#xff0c;制造業正經歷一場以智能化為核心的變革。傳統人工質檢模式因效率低、誤差率高、成本高昂等問題&#xff0c;逐漸難以滿足現代生產對高精度、高速度的需求。智能視覺檢測技術作為人工智能與機器視覺融合的產物&#xff0c;正成為制造業質量管控…

水滸后傳-暹羅國建立新國家的故事

第一節《怒海余生》 李俊率領殘部穿越臺風海域&#xff0c;在暹羅灣遭遇葡萄牙艦隊突襲。童猛為掩護船隊突圍&#xff0c;駕駛火船與敵艦同歸于盡&#xff0c;留下最后的忠義絕唱。 第二節《血染王城》 李俊與暹羅舊貴族勢力在曼谷河畔展開決戰。中原陣法與暹羅象兵碰撞出驚心…

1.portainer

容器可視化工具 商業版Business、社區版Community docker容器部署portainer&#xff0c;對外暴露端口9443是一個自簽名的證書端口。還有另外一個暴露的端口8000。 volume 要想看得到&#xff0c;需要通過 portainer可視化界面看到volume&#xff0c;就必須使用&#xff1a; d…

使用Starrocks制作拉鏈表

5月1日向ods_order_info插入3條數據&#xff1a; CREATE TABLE ods_order_info(dt string,id string COMMENT 訂單編號,total_amount decimal(10,2) COMMENT 訂單金額 ) PRIMARY KEY(dt, id) PARTITION BY (dt) DISTRIBUTED BY HASH(id) PROPERTIES ( "replication_num&q…

Linux下Docker使用阿里云鏡像加速器

在中國大陸環境中配置 Docker 使用阿里云鏡像加速器&#xff0c;并確保通過 Clash 代理訪問 Docker Hub 我這里用的Debian12。 步驟 1&#xff1a;獲取阿里云鏡像加速器地址 登錄阿里云容器鏡像服務控制臺&#xff1a;(qinyang.wang) 網址&#xff1a;阿里云登錄 - 歡迎登錄阿…

Electron 后臺常駐服務實現(托盤 + 開機自啟)

基于 electron-vite-vue 項目結構 本篇將詳細介紹如何為 Electron 應用實現后臺常駐運行&#xff0c;包括&#xff1a; ? 創建系統托盤圖標&#xff08;Tray&#xff09;? 支持點擊托盤菜單控制窗口顯示/退出? 實現開機自啟功能&#xff08;Auto Launch&#xff09; &#…

opencv的直方圖

理解并運用 OpenCV 中的圖像直方圖 &#x1f4ca;&#x1f5bc;? 圖像直方圖是計算機視覺和圖像處理中一種基本且強大的工具&#xff0c;它提供了圖像像素強度分布的圖形化表示。OpenCV 作為一個全面的計算機視覺庫&#xff0c;內置了計算和可視化直方圖的強大功能。本文將深…

Linux 內核探秘:從零構建 GPIO 設備驅動程序實戰指南

在嵌入式系統開發領域&#xff0c;GPIO&#xff08;通用輸入 / 輸出&#xff09;作為硬件與軟件交互的橋梁&#xff0c;是實現設備控制與數據采集的基礎。編寫高效、穩定的 GPIO 設備驅動程序&#xff0c;對于發揮硬件性能至關重要。本文將深入剖析 Linux 內核中 GPIO 驅動開發…

嵌入式單片機中STM32F1演示寄存器控制方法

該文以STM32F103C8T6為示例,演示如何使用操作寄存器的方法點亮(關閉LED燈),并講解了如何調試,以及使用宏定義。 第一:操作寄存器點亮LED燈。 (1)首先我們的目的是操作板子上的LED2燈,對其實現點亮和關閉操作。打開STM32F103C8T6的原理圖,找到LED2的位置。 可以看到…

牛客網 NC16407 題解:托米航空公司的座位安排問題

牛客網 NC16407 題解&#xff1a;托米航空公司的座位安排問題 題目分析 解題思路 本題可以采用深度優先搜索(DFS)來解決&#xff1a; 從左上角開始&#xff0c;按行優先順序遍歷每個座位對于每個座位&#xff0c;有兩種選擇&#xff1a; 選擇該座位&#xff08;如果滿足條件…

智慧展館數字孿生平臺

2022年進博會上&#xff0c;國家會展中心憑借“數字孿生機器人調度平臺”驚艷全球&#xff0c;實現人機協同、虛實聯動的智慧運營&#xff1b;2023年天府農博園通過“BIMIoT”技術&#xff0c;貫穿展館全生命周期管理&#xff0c;成為農業會展的數字化標桿。這些案例背后&#…

胡說八道1---豆包問答總結

用戶提問 1 指令&#xff1a;25 - - [21/May/2025:01:35:45 0000] “POST /prod-api/system/base/getList HTTP/1.1” 405 559 “http://192.168.1.109:16380/login” “Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 …

C# AOP編程

AOP(面向切片編程的概念我這里就不介紹了&#xff0c;這里先介紹一下C#中的AOP編程框架。 1.AOP的分類 .net下支持AOP的框架很多&#xff0c;搜了一下有&#xff1a;PostSharp、AspectInjector、Fody 、Castle Windsor、Spring.NET、Ninject、Unity等&#xff0c;實現的方式主要…

linux編譯安裝srs

下載編譯運行 git clone https://github.com/ossrs/srs.git cd srs/trunk ./configure --h265on make需要安裝 yum install -y patch yum install -y unzip yum install -y tcl編譯完成后即可啟動SRS # 啟動 ./objs/srs -c conf/srs.conf # 查看日志 tail -n 30 -f ./objs/s…

EtherNet/IP機柜內解決方案在醫療控制中心智能化的應用潛能和方向分析

引言 在數智化轉型浪潮席卷各行各業的今天,醫療領域同樣面臨著提升運營效率、改善患者體驗和加強系統可靠性的多重挑戰。Rockwell Automation于2025年5月20日推出的EtherNet/IP機柜內解決方案,為醫療中心的自動化升級提供了一種創新路徑。本報告將深入分析這一解決方案的核心…

大模型下載到本地

一、huggingface 方式一 from huggingface_hub import snapshot_downloadlocal_dir "./origin" model_name "Qwen/Qwen2.5-1.5B"# snapshot_download(repo_idmodel_name, cache_dirlocal_dir) model_dir snapshot_download(model_name,cache_dirlocal…

【C++】vector容器實現

目錄 一、vector的成員變量 二、vector手動實現 &#xff08;1&#xff09;構造 &#xff08;2&#xff09;析構 &#xff08;3&#xff09;尾插 &#xff08;4&#xff09;擴容 &#xff08;5&#xff09;[ ]運算符重載 5.1 迭代器的實現&#xff1a; &#xff08;6&…

PostgreSQL日常維護

目錄 一、PostgreSQL 概述 二、基本使用 &#xff08;一&#xff09;登錄數據庫 &#xff08;二&#xff09;數據庫操作 1. 列出數據庫 2. 創建數據庫 3. 刪除數據庫 4. 切換數據庫 5. 查看數據庫大小 &#xff08;三&#xff09;數據表操作 1. 列出表 2. 創建表 …