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'

相关推荐
梦无矶几秒前
nrm自动设置npm镜像源
前端·npm·node.js
鲤鱼_5998 分钟前
记录——前端开发IDEA需要的插件
前端
摘星编程14 分钟前
基于 JiuwenSwarm AgentTeam 构建混沌工程自动化实战
前端·chrome
nashane24 分钟前
HarmonyOS 6学习:Web组件与JavaScript交互的三大高频问题与终极解决方案
前端·学习·harmonyos
顾随32 分钟前
(2)达梦数据库--SQl基础实践
前端·数据库·sql
键盘飞行员33 分钟前
Windsurf + Claude 4.7 前端开发:用 ui-ux-pro-max 根治 “AI 味”、实现全站 UI 统一
前端·ui·ai编程
IT_陈寒34 分钟前
被JavaScript的隐式类型转换坑到怀疑人生,记录这次离谱经历
前端·人工智能·后端
梦无矶34 分钟前
快速设置npm默认源为国内全局镜像源
前端·npm·node.js
aichitang20241 小时前
HTML 实时预览工具
前端·html
广州智维科技1 小时前
Kvaser Edge WL400S:工业级边缘计算与 CAN‑FD 数据采集平台解析73-30130-01688-0
前端·edge·边缘计算