vite前端版本升级,刷新页面

创建versionUpdatePlugin文件

javascript 复制代码
// versionUpdatePlugin.js

const writeVersion = async (versionFile, content) => {
    const fs = await import('fs').then((module) => module.default);
    // 写入文件
    fs.writeFile(versionFile, content, (err) => {
        if (err) throw err
    })
}

export default (options) => {
    let config
    return {
        name: 'version-update',

        configResolved(resolvedConfig) {
            // 存储最终解析的配置
            config = resolvedConfig
        },

        async buildStart() {
            const fs = await import('fs').then((module) => module.default);
            const path = await import('path').then((module) => module.default)
            // 生成版本信息文件路径
            const file = config.publicDir + path.sep + 'version.json'
            // 这里使用编译时间作为版本信息
            const content = JSON.stringify({ version: options.version })
            if (fs.existsSync(config.publicDir)) {
                writeVersion(file, content)
            } else {
                fs.mkdir(config.publicDir, (err) => {
                    if (err) throw err
                    writeVersion(file, content)
                })
            }
        },
    }
}

修改vite.config.js文件

css 复制代码
1. const now = new Date().getTime(); // 定义一个时间戳

2.   plugins: [
    versionUpdatePlugin({
      version: now
    })
  ],
  plugins中引入versionUpdatePlugin方法
3. 定义全局变量
  define: {
    __APP_VERSION__: now,
  }

使用

javascript 复制代码
// 添加 beforeEach 导航守卫
router.beforeEach(async (to, from, next) => {
    await versionCheck() // 版本监控
    next()
});

// 版本监控
const versionCheck = async () => {
    if (process.env.NODE_ENV === 'development') return
    const response = await axios.get('version.json')
    if (__APP_VERSION__ !== response.data.version) {
        // console.log('有新版本,刷新页面');
        setTimeout(() => {
            window.location.reload()
        }, 500)
    }
}
相关推荐
条tiao条几秒前
不止语法糖:TypeScript Set 与 Map 深度解析
前端·javascript·typescript
freewlt21 分钟前
React Server Components 深度解析:从原理到实战的完整指南
前端·javascript·react.js
ZC跨境爬虫1 小时前
Playwright进阶操作:鼠标拖拽与各类点击实战(含自定义拖拽实例)
前端·爬虫·python·ui
小江的记录本1 小时前
【RabbitMQ】RabbitMQ核心知识体系全解(5大核心模块:Exchange类型、消息确认机制、死信队列、延迟队列、镜像队列)
java·前端·分布式·后端·spring·rabbitmq·mvc
心静财富之门1 小时前
《前端零基础入门:HTML + CSS + JavaScript 全套速查表(详细版 + 实例)》
前端·javascript·python
星空1 小时前
前端--A_4--HTML表单
前端
We་ct1 小时前
JS手撕:DOM操作 & 浏览器API高频场景详解
开发语言·前端·javascript·面试·状态模式·操作·考点
小江的记录本1 小时前
【RocketMQ】RocketMQ核心知识体系全解(5大核心模块:架构模型、事务消息两阶段提交、回查机制、延迟消息、顺序消息)
linux·运维·服务器·前端·后端·架构·rocketmq
三万棵雪松1 小时前
【Linux 物联网网关主控系统-Web部分(二)】
linux·前端·物联网
We་ct2 小时前
LeetCode 137. 只出现一次的数字 II:从基础到最优的两种解法详解
前端·数据结构·算法·leetcode·typescript·位运算