Vue发布新版本,强制更新代码的方式

文章描述了一个JavaScript应用中检查新版本的过程。它创建了一个version.json文件来定义版本号,然后在util目录下的updateVersion.js文件中使用axios获取远程版本信息并与本地存储的版本进行比较。如果版本不同,应用会更新localStorage并重新加载页面以应用新版本。此过程在路由的afterEach钩子中触发,确保每次导航时都进行版本检查。
摘要由CSDN通过智能技术生成

public下新建version.json文件定义版本

{
    "version":"1.1.0"
}   

util下新建updateVersion.js

import axios from 'axios'; 
import { Loading } from 'element-ui';
var t1;
var t2;
export async function isNewVersion() {
    var randomNumber=Math.random() 
    const url = `//${window.location.host}/version.json?id=${randomNumber}`;
    const res = await axios.get(url); 
    const version = res.data.version;
    const localVersion = localStorage.getItem('version');
    if (localVersion && localVersion != version) {
        localStorage.setItem('version', version);
        const hide=()=>{
            //我这里使用的是
            let loadingInstance =Loading.service({ fullscreen: true,text:'版本正在更新渲染加载中...'});
            clearTimeout(t1)
        }
        t1=setTimeout(hide,2000)
        t2=setTimeout(()=>{
            clearTimeout(t2)
            window.location.reload();
        },3000)
    } else {
        localStorage.setItem('version', version);
    }
}

router的afterEach的后置守卫中加版本查询,更新代码

rotuer/index.js

import {isNewVersion} from '@/util/updateVersion.js'
router.afterEach((to,from)=>{
  isNewVersion()
})
export default router

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

路光.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值