0
点赞
收藏
分享

微信扫一扫

Electron学习(二)之主进程与渲染进程的通讯

模拟主进程与渲染进程的通讯过程

渲染进程

根目录下添加​​renderer.js​​​,既支持​​node js​​​也支持​​dom js​​,示例代码如下:

//这是渲染进程
const {ipcRenderer}=require("electron")
//下面是从渲染进程向主进程发送消息
window.addEventListener('DOMContentLoaded',()=>{
ipcRenderer.send("message","I am from the rendering process!")
ipcRenderer.on("reply",(event, args)=>{
document.getElementById('message').innerHTML=args
})
})

主进程

示例代码如下:

const {app,BrowserWindow,ipcMain}=require("electron")
//ready:当electron完全加载,准备好创建BrowserWindow的时候
app.on('ready',()=>{
const win=new BrowserWindow({
width:800,
height:600,
webPreferences:{
//意思是在man.js中可以使用nodejs的api
nodeIntegration:true,
//加上这段代码后支持node Api
contextIsolation: false
}
})
win.loadFile("index.html");
ipcMain.on("message",(event, args)=>{
console.log(args)
// event.sender.send("reply","I am the main process,Over!")
// event.sender和win是一样的
win.send("reply","I am the main process,Over!")
})
})

index页面

示例代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<!-- https://developer.mozilla.org/en-US/docs/Web/HTTP/CSP -->
<meta http-equiv="Content-Security-Policy" content="default-src 'self'; script-src 'self'; style-src 'self' 'unsafe-inline'">
<link href="./styles.css" rel="stylesheet">
<title>Hello World!</title>
</head>
<body>
<h1>Hello World!</h1>
<p id="message"></p>
<!--渲染进程添加-->
<script src="./renderer.js"></script>

</body>
</html>

运行效果

Electron学习(二)之主进程与渲染进程的通讯_示例代码

优秀不够,你是否无可替代

软件测试交流QQ群:721256703,期待你的加入!!

欢迎关注我的微信公众号:软件测试君




举报

相关推荐

Electron[5] 渲染进程和主进程

0 条评论