vue 后台生产环境自动检测更新

typescript 复制代码
let lastSrcs: any; //上一次获取到的script地址

const scriptReg = /<script.*?type=['"]module['"].*?src=['"](.*?)['"].*?>/g;
/**
 * 获取最新页面中的script链接
 */
async function extractNewScript() {
    const env = import.meta.env.MODE
    if (env !== "production" ) return 
    const html = await fetch('/?_timestamp=' + Date.now()).then((res) => res.text());
    const result:any[] = [];
    // let match: any;
    scriptReg.lastIndex = 0
    const match = scriptReg.exec(html)
    if(match)result.push(match[1]);
    return result;
}
async function needUpdate() {
    const newScripts:any = await extractNewScript();
    if (!lastSrcs) {
        lastSrcs = newScripts;
        return false;
    }
    let result = false;
    if (lastSrcs.length !== newScripts.length) {
        result = true;
    }
    for (let i = 0; i < lastSrcs.length; i++) {
        if (lastSrcs[i] !== newScripts[i]) {
            result = true;
            break;
        }
    }
    lastSrcs = newScripts
    return result

}
const DURATION = 10000;
function autoRefresh() {
    setTimeout(async () => {
        const willUpdate = await needUpdate();
        if (willUpdate) {
            const result = confirm("页面有更新,点击确定刷新页面");
            if (result) {
                location.reload();
            }
        }
        autoRefresh();
    }, DURATION);
}
autoRefresh()

main.ts

import '@/utils/auto.update'

相关推荐
EndingCoder3 分钟前
箭头函数和 this 绑定
linux·前端·javascript·typescript
郑州光合科技余经理3 分钟前
架构解析:同城本地生活服务o2o平台海外版
大数据·开发语言·前端·人工智能·架构·php·生活
沐墨染5 分钟前
大型数据分析组件前端实践:多维度检索与实时交互设计
前端·elementui·数据挖掘·数据分析·vue·交互
xkxnq9 分钟前
第一阶段:Vue 基础入门(第 11 天)
前端·javascript·vue.js
lifejump9 分钟前
Pikachu | Unsafe Filedownload
前端·web安全·网络安全·安全性测试
Irene199114 分钟前
CSS新属性分类总结(2020年后引入)
前端·css
小oo呆14 分钟前
【自然语言处理与大模型】LangGraphV1.0入门指南:核心组件Nodes
前端·javascript·easyui
LongtengGensSupreme22 分钟前
后端设置了跨域但是还是提示跨域问题,原因是这里有两个独立的安全策略在起作用:Chrome和Edge浏览器安全策略强制修改方案
前端·chrome·edge·浏览器·跨域
程序员小李白23 分钟前
弹性盒子详细解析
前端·css·css3
行走的陀螺仪25 分钟前
在UniApp H5中,实现路由栈的持久化
前端·javascript·uni-app·路由持久化·路由缓存策略