当前位置: 首页 > article >正文

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

主进程 (main.js)

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)

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)

<!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>

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);
});


http://www.kler.cn/a/406857.html

相关文章:

  • 《生成式 AI》课程 作业6 大语言模型(LLM)的训练微调 Fine Tuning -- part2
  • VMware虚拟机Ubuntu桥接模式突然连接不上网络解决办法
  • logback动态获取nacos配置
  • 启动前后端分离项目笔记
  • spring-logback引用外部文件
  • 时序论文23|ICML24谷歌开源零样本时序大模型TimesFM
  • 大数据学习18之Spark-SQL
  • STL关联式容器之multiset及multimap
  • Flutter:AnimatedSwitcher当子元素改变时,触发动画
  • Ansible使用简介和基础使用
  • 嵌入式 UI 开发的开源项目推荐
  • C#学习笔记——窗口停靠控件WeifenLuo.WinFormsUI.Docking使用-腾讯云开发者社区-腾讯云
  • vue3中父div设置display flex,2个子div重叠
  • 华为无线AC+AP组网实际应用小结
  • FreeIPCC:Ai智能呼叫中心是什么?
  • 【数据结构】归并排序 —— 递归及非递归解决归并排序
  • 基于自混合干涉测量系统的线展宽因子估计算法matlab仿真
  • Python Matplotlib 安装指南:使用 Miniconda 实现跨 Linux、macOS 和 Windows 平台安装
  • MAC C语言 Helloword
  • spring学习(四)
  • DevOps 之 CI/CD入门操作 (二)
  • k8s上面的Redis集群链接不上master的解决办法
  • Powershell 命令行窗口 设置行宽、折行、行省略
  • IText创建加盖公章的pdf文件并生成压缩文件
  • 高级java每日一道面试题-2024年11月22日-JVM篇-说说堆和栈的区别?
  • 纯HTMLCSS实现3D旋转地球