纯前端umi项目部署页面自动刷新

背景

在用户正在访问单页面网站的情况下,突然发布了新的版本。而由于单页面中路由特性,或浏览器缓存的原因,并不会随着路由变化而重新加载前端资源,此时用户浏览器所运行的脚本,并非是最新的代码,从而可能引发一些问题。因此所引发了思考。如何在后端部署之后,提醒用户系统的版本更新,并且引导用户刷新页面,获取最新资源。

纯前端实现思路

可通过前端接收最新的版本信息,并且与本地的登陆时所保存的版本信息来进行比较,可使用轮训、websocket等技术来完成。

唯一hash值

  1. hash文件的生成
    创建hash.js文件,生成一个唯一值用于标识当前版本
js 复制代码
const crypto = require('crypto');
const fs = require('fs');
const data = crypto.randomBytes(16).toString('hex');
const hash = crypto.createHash('sha256').update(data).digest('hex');
fs.writeFile('./build/hash.txt', hash, (err) => {
  if (err) throw err;
});

修改package.json下的build命令

json 复制代码
 "build": "umi run build && node ./hash.js",

运行build命令之后就会生成hash.txt文件

  1. 判断时机

如果发版是在用户不常用的时间段,可以在浏览器visibility切换的回调 + 路由切换拦截时,这2个时机判断版本号,基本上完全够用了

jsx 复制代码
//app.jsx
import request from 'umi-request';

const getHash = () => {
  return request(`/hash.txt`);
};
//umi里getInitialState函数用于项目初始化时获取用户信息,这个时机可以添加逻辑进行判断
export async function getInitialState() {
  const data = await getHash();
    document.addEventListener('visibilitychange', async () => {
      console.log(document.visibilityState);
      if (document.visibilityState === 'visible') {
        const newdata = await getHash();
        if (data !== newdata) {
          window.location.reload();
        }
      } 
    });

    return {
      collapsed: false,
      hash: data,
      userInfo: currentUserResult?.body || {},
    };
}
export const layout = ({ location, initialState, setInitialState }) => {
  return {
    onPageChange: async (location) => {
      const data = await getHash();
      if (data !== initialState.hash) {
        window.location.reload();
      }

    },
    onCollapse: (arg) => {
      setInitialState({
        ...initialState,
        collapsed: arg,
      });
    },
    ...initialState?.settings,
  };
};

有不同方案的大佬请在评论区多多指教!

相关推荐
二两锅巴9 分钟前
📺 无需Electron!前端实现多显示器浏览器窗口精准控制与通信
前端
炸土豆13 分钟前
防抖节流里的this传递
前端·javascript
用户40993225021214 分钟前
Vue3中动态样式数组的后项覆盖规则如何与计算属性结合实现复杂状态样式管理?
前端·ai编程·trae
山璞16 分钟前
Flutter3.32 中使用 webview4.13 与 vue3 项目的 h5 页面通信,以及如何调试
前端·flutter
努力早日退休19 分钟前
Antd Image标签父元素会比图片本身高几个像素的原因
前端
林希_Rachel_傻希希19 分钟前
手写Promise--教学版本
前端·javascript·面试
ETA823 分钟前
`console.log([1,2,3].map(parseInt))` 深入理解 JavaScript 中的高阶函数与类型机制
前端·javascript
呼叫694523 分钟前
图片列表滚动掉帧的原因分析与解决方案
前端
狗哥哥26 分钟前
AI 驱动前端自动化测试:一套能落地、能协作、能持续的工程化方案
前端·测试
全栈老石30 分钟前
别再折腾端口转发了:使用 Cloudflare Tunnel 优雅地分享你的 localhost
前端·后端·全栈