Vue3实现优雅的前端版本更新提示

背景

在前端项目开发中,当我们发布了新版本后,需要及时通知用户刷新页面以获取最新代码。本文将介绍一种优雅的实现方案。

实现原理

  1. 在项目根目录维护一个version.json文件,记录当前版本号
  2. 前端定期请求version.json检查版本
  3. 对比本地存储的版本号,如有更新则提示用户

核心代码实现

1. 创建version.json

复制代码
{
"version": "1.0.0"
}

2. Vue组件实现

复制代码
import { ref, onMounted } from 'vue'
import { ElNotification } from 'element-plus'
// 检查版本更新
const checkVersion = async () => {
try {
// 添加时间戳防止缓存
const response = await fetch('/version.json?t=' + new Date().getTime())
const data = await response.json()
const localVersion = localStorage.getItem('app_version')
if (localVersion && localVersion !== data.version) {
showUpdateNotification()
}
localStorage.setItem('app_version', data.version)
} catch (error) {
console.error('检查版本更新失败:', error)
}
}
// 显示更新通知
const showUpdateNotification = () => {
ElNotification({
title: '系统更新提示',
message: '系统已更新,请刷新页面获取最新版本',
type: 'warning',
duration: 0,
onClick: () => window.location.reload()
})
}
// 组件挂载时初始化
onMounted(() => {
localStorage.removeItem('app_version') // 清除本地版本号
checkVersion() // 初始检查
setInterval(checkVersion, 1 60 1000) // 每分钟检查一次
})

实现要点

  1. 防止缓存: 请求version.json时添加时间戳参数

  2. 定时检查: 使用setInterval定期检查版本更新

  3. 用户体验:

    • 通知框持续显示(duration: 0)
    • 点击通知可直接刷新
    • 友好的提示文案
  4. 版本号存储: 使用localStorage存储版本号,便于对比

优化建议

  1. 可以根据业务需求调整检查频率

  2. 可以添加更新日志展示

  3. 对于正在编辑的内容,建议提示用户先保存

  4. 可以添加强制更新的机制

相关推荐
HjhIron9 小时前
从栈到队列,再到链表:前端开发者必知的线性数据结构
前端·javascript
PedroQue999 小时前
uni-app路由管理神器:vue-router风格体验
前端·uni-app
用户1733598075379 小时前
花两周用 Vue 3 做了个 PDF 工具站,我在生产环境踩了 8 个坑
前端·vue.js
风骏时光牛马9 小时前
TypeScript 泛型与工具类型实战:企业级通用数据请求封装完整案例
前端
阿猫的故乡9 小时前
Vue自定义指令从入门到实用:自动聚焦、权限控制、防抖、懒加载……全案例教学
前端·javascript·vue.js
嘟嘟07179 小时前
吃透 JS 八大数据类型与内存原理,从代码到底层一站式复习
前端
问心无愧05139 小时前
ctf show web入门157 158
前端·笔记
该用户已成仙9 小时前
vue3 使用 vuedraggable 报错 TypeError: isFunction2 is not a function
前端·javascript·vue.js
aidou13149 小时前
Kotlin中实现星级评价选择功能(仅支持整数)
前端·kotlin·自定义view·imageview·ontouchevent·customratingbar
良逍Ai出海9 小时前
我用 Codex 搭了一个 WordPress 独立站
前端