Quick Start to zh-CN

This commit is contained in:
Weiqiang Lin 2017-01-17 17:48:51 +08:00
parent 48facf6343
commit 96b7d3653c

View file

@ -5,68 +5,79 @@ Electron 可以让你使用纯 JavaScript 调用丰富的原生 APIs 来创造
这不意味着 Electron 是绑定了 GUI 库的 JavaScript。相反Electron 使用 web 页面作为它的 GUI所以你能把它看作成一个被 JavaScript 控制的,精简版的 Chromium 浏览器。 这不意味着 Electron 是绑定了 GUI 库的 JavaScript。相反Electron 使用 web 页面作为它的 GUI所以你能把它看作成一个被 JavaScript 控制的,精简版的 Chromium 浏览器。
## 主进程 ## 主进程
在 Electron 里,运行 `package.json``main` 脚本的进程被称为**主进程**。在主进程运行的脚本可以以创建 web 页面的形式展示 GUI。 在 Electron 里,运行 `package.json``main` 脚本的进程被称为**主进程**。在主进程运行的脚本可以以创建 web 页面的形式展示 GUI。
## 渲染进程 ## 渲染进程
由于 Electron 使用 Chromium 来展示页面,所以 Chromium 的多进程结构也被充分利用。每个 Electron 的页面都在运行着自己的进程,这样的进程我们称之为**渲染进程**。 由于 Electron 使用 Chromium 来展示页面,所以 Chromium 的多进程结构也被充分利用。每个 Electron 的页面都在运行着自己的进程,这样的进程我们称之为**渲染进程**。
在一般浏览器中网页通常会在沙盒环境下运行并且不允许访问原生资源。然而Electron 用户拥有在网页中调用 Node.js 的 APIs 的能力,可以与底层操作系统直接交互。 在一般浏览器中网页通常会在沙盒环境下运行并且不允许访问原生资源。然而Electron 用户拥有在网页中调用 Node.js 的 APIs 的能力,可以与底层操作系统直接交互。
## 主进程与渲染进程的区别 ## 主进程与渲染进程的区别
主进程使用 `BrowserWindow` 实例创建页面。每个 `BrowserWindow` 实例都在自己的渲染进程里运行页面。当一个 `BrowserWindow` 实例被销毁后,相应的渲染进程也会被终止。 主进程使用 `BrowserWindow` 实例创建页面。每个 `BrowserWindow` 实例都在自己的渲染进程里运行页面。当一个 `BrowserWindow` 实例被销毁后,相应的渲染进程也会被终止。
主进程管理所有页面和与之对应的渲染进程。每个渲染进程都是相互独立的,并且只关心他们自己的页面。 主进程管理所有页面和与之对应的渲染进程。每个渲染进程都是相互独立的,并且只关心他们自己的页面。
由于在页面里管理原生 GUI 资源是非常危险而且容易造成资源泄露,所以在页面调用 GUI 相关的 APIs 是不被允许的。如果你想在网页里使用 GUI 操作,其对应的渲染进程必须与主进程进行通讯,请求主进程进行相关的 GUI 操作。 由于在页面里管理原生 GUI 资源是非常危险而且容易造成资源泄露,所以在页面调用 GUI 相关的 APIs 是不被允许的。如果你想在网页里使用 GUI 操作,其对应的渲染进程必须与主进程进行通讯,请求主进程进行相关的 GUI 操作。
在 Electron我们提供几种方法用于主进程和渲染进程之间的通讯。像 [ipcRenderer][1] 和 [ipcMain][2] 模块用于发送消息, [remote][3] 模块用于 RPC 方式通讯。这些内容都可以在一个 FAQ 中查看 [how to share data between web pages][4]。 在 Electron我们提供几种方法用于主进程和渲染进程之间的通讯。像 [`ipcRenderer`](../api/ipc-renderer.md) 和 [`ipcMain`](../api/ipc-main.md) 模块用于发送消息, [remote](../api/remote.md) 模块用于 RPC 方式通讯。这些内容都可以在一个 FAQ 中查看 [how to share data between web pages][share-data]。
# 打造你第一个 Electron 应用 # 打造你第一个 Electron 应用
大体上,一个 Electron 应用的目录结构如下: 大体上,一个 Electron 应用的目录结构如下:
````
```text
your-app/ your-app/
├── package.json ├── package.json
├── main.js ├── main.js
└── index.html └── index.html
```` ```
`package.json` 的格式和 Node 的完全一致,并且那个被 `main` 字段声明的脚本文件是你的应用的启动脚本,它运行在主进程上。你应用里的 `package.json` 看起来应该像: `package.json` 的格式和 Node 的完全一致,并且那个被 `main` 字段声明的脚本文件是你的应用的启动脚本,它运行在主进程上。你应用里的 `package.json` 看起来应该像:
```javascripton
```json
{ {
"name" : "your-app", "name" : "your-app",
"version" : "0.1.0", "version" : "0.1.0",
"main" : "main.js" "main" : "main.js"
} }
``` ```
**注意**:如果 `main` 字段没有在 `package.json` 声明Electron会优先加载 `index.js` **注意**:如果 `main` 字段没有在 `package.json` 声明Electron会优先加载 `index.js`
`main.js` 应该用于创建窗口和处理系统事件,一个典型的例子如下: `main.js` 应该用于创建窗口和处理系统事件,一个典型的例子如下:
```javascript ```javascript
const electron = require('electron') const {app, BrowserWindow} = require('electron')
// 控制应用生命周期的模块。 const path = require('path')
const {app} = electron const url = require('url')
// 创建原生浏览器窗口的模块。
const {BrowserWindow} = electron
// 保持一个对于 window 对象的全局引用,如果你不这样做, // 保持一个对于 window 对象的全局引用,如果你不这样做,
// 当 JavaScript 对象被垃圾回收, window 会被自动地关闭 // 当 JavaScript 对象被垃圾回收, window 会被自动地关闭
let mainWindow let win
function createWindow () { function createWindow () {
// 创建浏览器窗口。 // 创建浏览器窗口。
mainWindow = new BrowserWindow({width: 800, height: 600}) win = new BrowserWindow({width: 800, height: 600})
// 加载应用的 index.html。 // 加载应用的 index.html。
mainWindow.loadURL(`file://${__dirname}/index.html`) win.loadURL(url.format({
pathname: path.join(__dirname, 'index.html'),
protocol: 'file:',
slashes: true
}))
// 启用开发工具。 // 打开开发者工具。
mainWindow.webContents.openDevTools() win.webContents.openDevTools()
// 当 window 被关闭,这个事件会被触发。 // 当 window 被关闭,这个事件会被触发。
mainWindow.on('closed', () => { win.on('closed', () => {
// 取消引用 window 对象,如果你的应用支持多窗口的话, // 取消引用 window 对象,如果你的应用支持多窗口的话,
// 通常会把多个 window 对象存放在一个数组里面, // 通常会把多个 window 对象存放在一个数组里面,
// 与此同时,你应该删除相应的元素。 // 与此同时,你应该删除相应的元素。
mainWindow = null win = null
}) })
} }
@ -85,9 +96,9 @@ app.on('window-all-closed', () => {
}) })
app.on('activate', () => { app.on('activate', () => {
// 在 macOS 上,当点击 dock 图标并且该应用没有打开的窗口时, // 在这文件,你可以续写应用剩下主进程代码。
// 绝大部分应用会重新创建一个窗口 // 也可以拆分成几个文件,然后用 require 导入
if (mainWindow === null) { if (win === null) {
createWindow() createWindow()
} }
}) })
@ -95,7 +106,9 @@ app.on('activate', () => {
// 在这文件,你可以续写应用剩下主进程代码。 // 在这文件,你可以续写应用剩下主进程代码。
// 也可以拆分成几个文件,然后用 require 导入。 // 也可以拆分成几个文件,然后用 require 导入。
``` ```
最后,你想展示的 `index.html` 最后,你想展示的 `index.html`
```html ```html
<!DOCTYPE html> <!DOCTYPE html>
<html> <html>
@ -113,42 +126,65 @@ app.on('activate', () => {
``` ```
# 运行你的应用 # 运行你的应用
一旦你创建了最初的 `main.js` `index.html``package.json` 这几个文件,你可能会想尝试在本地运行并测试,看看是不是和期望的那样正常运行。 一旦你创建了最初的 `main.js` `index.html``package.json` 这几个文件,你可能会想尝试在本地运行并测试,看看是不是和期望的那样正常运行。
## electron-prebuilt ## electron-prebuilt
[electron-prebuilt][5] 是一个 `npm` 模块,包含所使用的 Electron 预编译版本。
[`electron`](https://github.com/electron-userland/electron-prebuilt) 是一个 `npm` 模块,包含所使用的 Electron 预编译版本。
如果你已经用 `npm` 全局安装了它,你只需要按照如下方式直接运行你的应用: 如果你已经用 `npm` 全局安装了它,你只需要按照如下方式直接运行你的应用:
```bash ```bash
electron . electron .
``` ```
如果你是局部安装,那运行: 如果你是局部安装,那运行:
#### macOS / Linux
```bash ```bash
./node_modules/.bin/electron . $ ./node_modules/.bin/electron .
```
#### Windows
```bash
$ .\node_modules\.bin\electron .
``` ```
## 手工下载 Electron 二进制文件 ## 手工下载 Electron 二进制文件
如果你手工下载了 Electron 的二进制文件,你也可以直接使用其中的二进制文件直接运行你的应用。 如果你手工下载了 Electron 的二进制文件,你也可以直接使用其中的二进制文件直接运行你的应用。
### Windows ### Windows
```bash ```bash
$ .\electron\electron.exe your-app\ $ .\electron\electron.exe your-app\
``` ```
### Linux ### Linux
```bash ```bash
$ ./electron/electron your-app/ $ ./electron/electron your-app/
``` ```
### macOS ### macOS
```bash ```bash
$ ./Electron.app/Contents/MacOS/Electron your-app/ $ ./Electron.app/Contents/MacOS/Electron your-app/
``` ```
`Electron.app` 里面是 Electron 发布包,你可以在 [这里][6] 下载到。
`Electron.app` 里面是 Electron 发布包,你可以在 [这里](https://github.com/electron/electron/releases) 下载到。
# 以发行版本运行 # 以发行版本运行
在你完成了你的应用后,你可以按照 [应用部署][7] 指导发布一个版本,并且以已经打包好的形式运行应用。
在你完成了你的应用后,你可以按照 [应用部署](./application-distribution.md) 指导发布一个版本,并且以已经打包好的形式运行应用。
# 参照下面例子 # 参照下面例子
复制并且运行这个库 [electron/electron-quick-start][8]。
*注意:*运行时需要你的系统已经安装了 [Git][9] 和 [Node.js][10](包含 [npm][11])。 复制并且运行这个库 [`electron/electron-quick-start`](https://github.com/electron/electron-quick-start)。
**注意:**运行时需要你的系统已经安装了 [Git](https://git-scm.com) 和 [Node.js](https://nodejs.org/en/download/)(包含 [npm](https://npmjs.org))。
```bash ```bash
# 克隆这仓库 # 克隆这仓库
@ -158,14 +194,7 @@ $ cd electron-quick-start
# 安装依赖库并运行应用 # 安装依赖库并运行应用
$ npm install && npm start $ npm install && npm start
``` ```
[1]: https://github.com/electron/electron/blob/v1.1.3/docs/api/ipc-renderer.md
[2]: https://github.com/electron/electron/blob/v1.1.3/docs/api/ipc-main.md 更多 apps 例子,查看 electron 社区创建的 [list of boilerplates](http://electron.atom.io/community/#boilerplates)。
[3]: https://github.com/electron/electron/blob/v1.1.3/docs/api/remote.md
[4]: https://github.com/electron/electron/blob/v1.1.3/docs/faq/electron-faq.md#how-to-share-data-between-web-pages [share-data]: ../faq.md#how-to-share-data-between-web-pages
[5]: https://github.com/electron-userland/electron-prebuilt
[6]: https://github.com/electron/electron/releases
[7]: https://github.com/electron/electron/blob/v1.1.3/docs/tutorial/application-distribution.md
[8]: https://github.com/electron/electron-quick-start
[9]: https://git-scm.com/
[10]: https://nodejs.org/en/download/
[11]: https://www.npmjs.com/