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

Electron: 主进程和渲染进程之间通信

// 渲染进程 向 主进程 异步通信// preload.js 预加载
const {ipcRenderer} = require('electron')
ipcRenderer.send('on-send-event', '这里是需要传递的参数') // 第一步ipcRenderer.on('on-resend-event', (e, data) => {console.log(data) // 打印的是ipcMain.on传递过来的参数:这里还是传递的参数
}) // 第四步也就是最后一步// main.js  主进程
const {ipcMain} = require('electron')
// 第二步
ipcMain.on('on-send-event', (e, data) => {console.log(data) // 打印的是ipcRenderer.send传递过来的参数:这里是需要传递的参数// 主进程主动给渲染进程传递信息(e.sender就是ipcMain)e.sender.send('on-resend-event', '这里还是传递的参数') // 第三步
})

// 渲染进程 向 主进程 同步通信// preload.js 预加载
const {ipcRenderer} = require('electron')
const val = ipcRenderer.sendSync('on-send-event', '这里是需要传递的参数') // 第一步
console.log(val) // 第四步, 同步接收第三步传递过来的参数:来自于主进程的同步信息// main.js  主进程
const {ipcMain} = require('electron')
// 第二步
ipcMain.on('on-send-event', (e, data) => {console.log(data) // 打印的是ipcRenderer.send传递过来的参数:这里是需要传递的参数// 主进程主动给渲染进程传递信息(e.sender就是ipcMain)e.returnValue = '来自于主进程的同步信息' // 第三步
})

主进程主动给渲染进程通信代码如下

// 主进程 向 渲染进程 通信// main.js  主进程
const {ipcMain, BroserWindow} = require('electron')
// 第一步,在自定义菜单Menu的click事件触发
click() {// BrowserWindow.getFocusedWindow:获取当前窗口BrowserWindow.getFocusedWindo().webContents.send('mtp', '来自主进程')
}// preload.js 预加载
const {ipcRenderer} = require('electron')// 第二步
ipcRenderer.on('mtp', (e, data) => {console.log(data) // 打印的是BrowserWindow.getFocusedWindo().webContents.send传递过来的参数:来自主进程}) 

实现从子窗口点击按钮后传递数据给父窗口的渲染进程实现逻辑:由子窗口的渲染进程传递消息给主进程,然后再由主进程传递消息给主进程的html渲染进程

// preload.js 预加载
const {ipcRenderer} = require('electron')ipcRenderer.send('mtp', '我是参数') 
ipcRenderer.on('mti', (e, data) => {// 接收到数据data
}) // main.js  主进程
const {ipcMain, BroserWindow} = require('electron')let mainWindowId = null;
function createWindow() {const mainWindow = new BrowserWindow({width: 1000,height: 800,webPreferences: {}})mainWindowId = mainWindow.id
}ipcMain.on('mtp', (e, data) => {// data:我是参数let mainWin = BroserWindow.fromId(mainWinId)mainWin.webContents.send('mti', data) // 主进程给渲染进程html传递数据
})

http://www.lryc.cn/news/486209.html

相关文章:

  • 社交电商的优势及其与 AI 智能名片小程序、S2B2C 商城系统的融合发展
  • 蓝桥杯c++算法学习【4】之简单数论(阶乘约数、求值、循环小数、等差数列、最大比例:::非常典型的必刷例题!!!)
  • 重构代码之删除对参数的赋值
  • Docker的基本概念、安装步骤以及一些简单的用法
  • VuePress v2 快速搭建属于自己的个人博客网站
  • shell编程--永久环境变量和字符串显位
  • 【优选算法篇】算法江湖中的碎玉拾光——C++模拟题全解,踏步逐章细细品味
  • 【MySQL 保姆级教学】事务的隔离级别(详细)--下(14)
  • 部分利用oracle数据字典查询对应信息的语句。
  • 实例教程:BBDB为AHRS算法开发提供完善的支撑环境(上)
  • k8s搭建1.23版本
  • 【MYSQL】分库分表
  • CSS基础知识05(弹性盒子、布局详解,动画,3D转换,calc)
  • 常见error集合
  • 建筑施工特种作业人员安全生产知识试题
  • 2024140读书笔记|《作家榜名著:生如夏花·泰戈尔经典诗选》——你从世界的生命的溪流浮泛而下,终于停泊在我的心头
  • JSP是如何被执行的?
  • 用python中的tkinter包实现进度条
  • oneplus3t-lineageos-16.1编译-android9
  • VSCode+ESP-IDF开发ESP32-S3-DevKitC-1(1)开发环境搭建
  • LeetCode --- 143周赛
  • [AI] 【提高认知】自动翻译技术的演变:从规则系统到深度学习的崛起
  • python机器人Agent编程——多Agent框架的底层逻辑(上)
  • 渑池县中药材产业党委莅临河南广宇企业管理集团有限公司参观交流
  • 学习日志011--模块,迭代器与生成器,正则表达式
  • ChatGPT 搜索 vs Google 搜索
  • 一文简单了解Android中的input流程
  • 【MySQL】SQL语言
  • 5.4.2-1 编写Java程序在HDFS上创建文件
  • The 3rd Universal CupStage 15: Chengdu, November 2-3, 2024(2024ICPC 成都)