add new file: ipc-main-process.md

This commit is contained in:
jinhai.wang 2015-10-11 13:52:06 +08:00
parent 6d20d37101
commit 6ec184a2ce

View file

@ -0,0 +1,68 @@
# ipc (主进程)
在主进程使用`ipc`模块时,`ipc`负责捕获从渲染进程(网页)发送的同步或者是异步消息.
## 发送消息
主进程也可以向渲染进程发送信息,具体可以看[WebContents.send](web-contents.md#webcontentssendchannel-args).
- 当发送消息的时候,事件名字为'channel'.
- 回复一个同步消息的时候,你需要使用`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';
});
```
```javascript
// 在渲染进程(网页).
var ipc = require('ipc');
console.log(ipc.sendSync('synchronous-message', 'ping')); // 打印 "pong"
ipc.on('asynchronous-reply', function(arg) {
console.log(arg); // 打印 "pong"
});
ipc.send('asynchronous-message', 'ping');
```
## 监听消息
`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` (选用)
这个可以发送一个可带参数的异步消息回渲染进程.