electron/docs-translations/zh-CN/api/ipc-main-process.md

69 lines
1.7 KiB
Markdown
Raw Normal View History

2015-10-11 05:52:06 +00:00
# ipc (主进程)
在主进程使用`ipc`模块时,`ipc`负责捕获从渲染进程(网页)发送的同步或者是异步消息.
## 发送消息
主进程也可以向渲染进程发送信息,具体可以看[WebContents.send](web-contents.md#webcontentssendchannel-args).
- 当发送消息的时候,事件名字为`channel`.
2015-10-11 05:52:06 +00:00
- 回复一个同步消息的时候,你需要使用`event.returnValue`
- 回复一个异步消息的时候,使用`event.sender.send(...)`
下面是一个主进程和渲染进程的通信例子.
```javascript
// 在主进程中.
var ipc = require('ipc')
ipc.on('asynchronous-message', function (event, arg) {
console.log(arg) // 打印 "ping"
event.sender.send('asynchronous-reply', 'pong')
})
ipc.on('synchronous-message', function (event, arg) {
console.log(arg) // 打印 "ping"
event.returnValue = 'pong'
})
2015-10-11 05:52:06 +00:00
```
```javascript
// 在渲染进程(网页).
var ipc = require('ipc')
console.log(ipc.sendSync('synchronous-message', 'ping')) // 打印 "pong"
2015-10-11 05:52:06 +00:00
ipc.on('asynchronous-reply', function (arg) {
console.log(arg) // 打印 "pong"
})
ipc.send('asynchronous-message', 'ping')
2015-10-11 05:52:06 +00:00
```
## 监听消息
`ipc`模块有下列几种方法来监听事件.
### `ipc.on(channel, callback)`
* `channel` - 事件名称.
* `callback` - 回调函数.
当事件发生的时候,会传入`callback` `event`和`arg`参数.
## IPC 事件
传入`callback`的`event`对象含有下列方法.
### `Event.returnValue`
在同步消息中,设置这个值将会被返回.
### `Event.sender`
返回一个可以发送消息的`WebContents`.
### `Event.sender.send(channel[.arg1][,arg2][,...])`
* `channel` - 事件名称.
* `arg` (选用)
这个可以发送一个可带参数的异步消息回渲染进程.