electron主进程和渲染进程之间的通信

主进程 (main.js)

bash 复制代码
const { app, BrowserWindow, ipcMain } = require("electron");
const path = require("node:path");
// 导入fs模块
const fs = require("fs");

const createWindow = () => {
  const win = new BrowserWindow({
    width: 800,
    height: 600,
    webPreferences: {
      preload: path.join(__dirname, "preload.js"),
    },
  });
  win.loadFile("index.html");
};
app.whenReady().then(() => {
  createWindow();
});

// 主进程接收渲染进程发送的消息
ipcMain.on("message-from-renderer", (event, data) => {
  let baseDir = "D:\\"; //保存的根路径
  let FileLocation = "001.text"; //文件名
  const url = path.join(baseDir, FileLocation);
  // 调用fs.writeFile() 写入文件内容
  fs.writeFile(url, data, function (err) {
    if (err) {
      return console.log("File write error" + err.message);
    }
    console.log("File write success");
    // 收到消息后给子窗口child回复消息
    event.sender.send("reply-msg-child", "我是父窗口,我接收到了子窗口的消息");
  });
});

预加载脚本 (preload.js)

bash 复制代码
const { contextBridge, ipcRenderer } = require("electron");

contextBridge.exposeInMainWorld("versions", {
  node: process.versions.node,
  chrome: process.versions.chrome,
  electron: process.versions.electron,
});

contextBridge.exposeInMainWorld("api", {
  send: (channel, data) => {
    ipcRenderer.send(channel, data);
  },
  receive: (channel, func) => {
    ipcRenderer.on(channel, (event, ...args) => func(...args));
  },
});

渲染进程 (index.html 和 renderer.js)

bash 复制代码
<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <meta
      http-equiv="Content-Security-Policy"
      content="default-src 'self'; script-src 'self'"
    />
    <meta
      http-equiv="X-Content-Security-Policy"
      content="default-src 'self'; script-src 'self'"
    />
    <title>Hello from Electron renderer!</title>
  </head>
  <body>
    <p id="info"></p>
    <button id="btn1">点击</button>
  </body>
  <script src="./renderer.js"></script>
</html>
bash 复制代码
const information = document.getElementById("info");
console.log(window);
information.innerText = `This app is using Chrome (v${versions.chrome}), Node.js (v${versions.node}), and Electron (v${versions.electron})`;

const btn1 = document.getElementById("btn1");

btn1.onclick = function () {
  // 发送消息到主进程
  window.api.send("message-from-renderer", "Hello from Renderer Process");
};

// 接收来自主进程的回应
window.api.receive("reply-msg-child", (args) => {
  alert(args);
});
相关推荐
kyriewen111 小时前
给浏览器画个圈:CSS contain 如何让页面从“卡成PPT”变“丝滑如德芙”
开发语言·前端·javascript·css·chrome·typescript·ecmascript
英俊潇洒美少年1 小时前
react19和vue3的优缺点 对比
前端·javascript·vue.js·react.js
~无忧花开~3 小时前
React生命周期全解析
开发语言·前端·javascript·react.js·前端框架·react
哈__3 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-maps
javascript·react native·react.js
SuperEugene4 小时前
Axios + Vue 错误处理规范:中后台项目实战,统一捕获系统 / 业务 / 接口异常|API 与异步请求规范篇
前端·javascript·vue.js·前端框架·axios
行走的陀螺仪4 小时前
手写 Vue3 极简 i18n
前端·javascript·vue.js·国际化·i18n
羽沢314 小时前
一篇简单的STOMP教程QAQ
前端·javascript·stomp
Kel4 小时前
深入 OpenAI Node SDK:一个请求的奇幻漂流
javascript·人工智能·架构
子兮曰4 小时前
AI写代码坑了90%程序员!这5个致命bug,上线就炸(附避坑清单)
前端·javascript·后端
终端鹿5 小时前
Vue3 核心 API 补充解析:toRef / toRefs / unref / isRef
前端·javascript·vue.js