小记:把react项目从web迁移到electron

electron的启动模版:electron项目启动模版资源-CSDN文库

使用vite构建,包含了react react-router-dom tailwindcss mui 主副进程通讯

使用:

解压后使用vscode打开

终端里:npm install

然后npm run dev

打包:

windows系统计算机

npm run build:win

国产操作系统计算机

npm run build:linux

javascript 复制代码
src/main/index.js:

//创建窗口,ipc通讯
..............

  //更新单位名称
  ipcMain.on("updatecompany", async (event, arg) => {
    // console.log(arg);
    const settings = {
      method: "PUT",
      headers: {
        Accept: "application/json",
        "Content-Type": "application/json"
      },
      body: JSON.stringify({
        companyname: `${arg}`
      })
    };
    const res = await fetch(`http://192.168.1.99:7077/api/v1/store/company`, settings);
    const data = await res.json();
    event.returnValue = data;
  });

  //获取单位名称
  ipcMain.on("getcompany", async (event) => {
    const res = await fetch(`http://192.168.1.99:7077/api/v1/store/company`);
    const data = await res.json();
    event.returnValue = data;
  });

...............
javascript 复制代码
scr/preload/index.js

import { contextBridge } from "electron";
import { electronAPI } from "@electron-toolkit/preload";

// Custom APIs for renderer
const api = {};

// Use `contextBridge` APIs to expose Electron APIs to
// renderer only if context isolation is enabled, otherwise
// just add to the DOM global.
if (process.contextIsolated) {
  try {
    contextBridge.exposeInMainWorld("electron", electronAPI);
    contextBridge.exposeInMainWorld("api", api);
  } catch (error) {
    console.error(error);
  }
} else {
  window.electron = electronAPI;
  window.api = api;
}

src/renderer/scr/....:

company.jsx 示例文件

javascript 复制代码
...
useEffect(() => {
     //ipc通讯
   
     const result = window.electron.ipcRenderer.sendSync("getcompany");
     companyRef.current.value = result.companyname;
  }, []);
...

home.jsx 主页文件

main.jsx 启动文件

routemain.jsx 路由定义文件

相关推荐
Hilaku37 分钟前
我用 Gemini 3 Pro 手搓了一个并发邮件群发神器(附源码)
前端·javascript·github
IT_陈寒37 分钟前
Java性能调优实战:5个被低估却提升30%效率的JVM参数
前端·人工智能·后端
快手技术38 分钟前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱40 分钟前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
全栈前端老曹1 小时前
【包管理】npm init 项目名后底层发生了什么的完整逻辑
前端·javascript·npm·node.js·json·包管理·底层原理
HHHHHY1 小时前
mathjs简单实现一个数学计算公式及校验组件
前端·javascript·vue.js
boooooooom1 小时前
Vue3 provide/inject 跨层级通信:最佳实践与避坑指南
前端·vue.js
一颗烂土豆1 小时前
Vue 3 + Three.js 打造轻量级 3D 图表库 —— chart3
前端·vue.js·数据可视化
青莲8431 小时前
Android 动画机制完整详解
android·前端·面试
iReachers1 小时前
HTML打包APK(安卓APP)中下载功能常见问题和详细介绍
前端·javascript·html·html打包apk·网页打包app·下载功能