electron 多窗口 vuex/pinia 数据状态同步简易方案(利用 LocalStorage)

全局 stroe 添加 mutations 状态同步方法

ts 复制代码
  // 用于其他窗口同步 vuex 中的 DeviceTcpData
  asyncDeviceTcpData(state: StateType, data: any) {
    state.deviceTcpData = data
  },

App.vue 里

ts 复制代码
onMounted(() => {
  console.log("App mounted");
  /**
   * vuex 多窗口 store 同步
   */
   // 1. 初始赋值
  // 从 localStorage 同步 tcp 上报的数据到 vuex
  const deviceTcpData = localStorage.getItem("deviceTcpData");
  if (deviceTcpData) {
    store.commit("asyncDeviceTcpData", JSON.parse(deviceTcpData));
  }
  // 2. 监听 storage 事件 同步 全局 state
  // 其他渲染进程,当设置进程进行修改storage的时候,其他进程可以根据storage变化来更改自己的store
  window.addEventListener("storage", () => {
    const deviceTcpData = localStorage.getItem("deviceTcpData");
    deviceTcpData &&
      store.commit("asyncDeviceTcpData", JSON.parse(deviceTcpData));
  });
  
    // 从主界面关闭时,清空本地存储的数据 (清除 localstorage 的时机)
  window.addEventListener("beforeunload", (e: any) => {
    if (route.name === "search") {
      localStorage.removeItem("deviceTcpData");
    }
  });
});

关键: 利用 watch 监听全局 state 的变动,每次变动,进行 localStorage 同步

ts 复制代码
// 监听 全局 store 的变动
watch(
  () => store.state.deviceTcpData,
  (val) => {
    console.log("watch 触发");
    console.log(val);
    localStorage.setItem("deviceTcpData", JSON.stringify(val));
  },
  {
    deep: true,
  }
);

缺点: 数据量大时,消耗性能较高。可用作少量数据的同步方案;

相关推荐
i_am_a_div_日积月累_2 天前
2.预加载(preload)
electron
七十二時_阿川2 天前
Electron 如何自定义菜单?这篇帮你实现原生体验!
前端·electron
七十二時_阿川2 天前
Electron App 速查表:生命周期事件、方法、平台差异
前端·electron
七十二時_阿川2 天前
Electron 多显示器开发?这篇帮你搞定屏幕坐标与窗口定位!
前端·electron
七十二時_阿川2 天前
Electron Tray API 详解:托盘图标、右键菜单、气泡通知
前端·electron
七十二時_阿川3 天前
Electron WebContents 完全指南:页面渲染、导航控制与安全实战
前端·electron
七十二時_阿川3 天前
Electron 主进程和渲染进程如何通信?这篇讲清楚了
前端·electron
七十二時_阿川3 天前
从零到精通:Electron 窗口管理高级技巧
前端·electron
会周易的程序员3 天前
aiDgeScanner:工业设备扫描与管理的一体化利器——深度解析上位机与扫描端的无缝协作
c++·物联网·typescript·electron·vue·iot·aiot
三声三视3 天前
Electron 在鸿蒙 PC 上启动慢?我把冷启动从 7 秒压到 1.5 秒的完整记录
electron·harmonyos·桌面应用