自动获取新版本 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.mzph.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. 创建表 …