通过socket设置版本更新提示

1.项目使用的是git所以使用git仓库的短哈希作为版本更新标识,将该字符写入public文件,此处需要注意后端访问静态资源的路径。

在vue.config.js文件中写入

复制代码
function excuteVersion() {
    const fs = require('fs')
    const { execSync } = require('child_process')
// 获取当前Git仓库的短提交哈希,将其存储在cmtId变量中
    const cmtId = execSync('git rev-parse --short HEAD').toString().trim()
// 将cmtId写⼊到public⽬录下的v.txt⽂件中
    const versionFile = path.join(process.cwd(), 'public/static/market', 'version.txt')
    fs.writeFileSync(versionFile, cmtId)
}

excuteVersion()

写入后 监听后端socket的版本更新消息通知

创建一个ts文件监听消息

复制代码
export function wsListenVersion() {
    const wsStore = useWsStore();

    wsStore.on(WS_EVENT.VERSION_UPDATE,(data)=>{
        wsLogger(WS_STATUS.RECEIVED, WS_EVENT.VERSION_UPDATE, data);
        if (data.code === HTTP_CODE.SUCCESS) {
            showUpdateModal(data.data.new)
        }
    })
}

设置通知的样式

复制代码
export function showUpdateModal(newCommitId: string) {
    const key = `open${newCommitId}`;
    notification.open({
        message: "页面已经发生了更新",
        description:
            "检测到当前页面内容已经发生了更新,请刷新页面后使用!",
        btn: () =>
            h(
                Button,
                {
                    type: "primary",
                    size: "small",
                    onClick: () => {
                        window.location.reload();
                        notification.close(key);
                    }
                },
                {default: () => "刷新"}
            ),
        key,
        placement: "bottomRight"
    });
}

在首页加载创建socket连接成功后监听该通知

复制代码
onMounted(()=>{
// 登录后初始化socket连接
	initWs()
})

function initWs(): Promise<void> {
  return new Promise<void>(resolve => {
    wsStore
        .connect()
        .then(() => {
		  wsListenVersion();
          resolve();
        })
        .catch(reason => console.log("[ERROR][WS]", reason));
  });
}

以上通过学习参考该文章

https://blog.csdn.net/Ljq1041054607/article/details/140955141

相关推荐
Mintopia6 分钟前
🤖 微服务架构下 WebAI 服务的高可用技术设计
前端·javascript·aigc
江城开朗的豌豆21 分钟前
React 跨级组件通信:避开 Context 的那些坑,我还有更好的选择!
前端·javascript·react.js
吃饺子不吃馅1 小时前
root.render(<App />)之后 React 干了哪些事?
前端·javascript·面试
鹏多多1 小时前
基于Vue3+TS的自定义指令开发与业务场景应用
前端·javascript·vue.js
江城开朗的豌豆1 小时前
Redux 与 MobX:我的状态管理选择心路
前端·javascript·react.js
Cosolar1 小时前
前端如何实现VAD说话检测?
前端
CodeSheep2 小时前
当了leader才发现,大厂最想裁掉的,不是上班总迟到的,也不是下班搞失联的,而是经常把这3句话挂在嘴边的
前端·后端·程序员
吃饺子不吃馅2 小时前
✨ 你知道吗?SVG 里藏了一个「任意门」——它就是 foreignObject! 🚪💫
前端·javascript·面试
IT_陈寒2 小时前
Python开发者必须掌握的12个高效数据处理技巧,用过都说香!
前端·人工智能·后端
gnip10 小时前
企业级配置式表单组件封装
前端·javascript·vue.js