简介

所有的Node.js's built-in modules在Electron中都可用,并且所有的node的第三方组件也可以放心使用(包括自身的模块)。

Electron也提供了一些额外的内置组件来开发传统桌面应用。一些组件只可以在主进程中使用,一些只可以在渲染进程中使用,但是也有部分可以在这2种进程中都可使用。

基本规则:GUI模块或者系统底层的模块只可以在主进程中使用。要使用这些模块,你应当很熟悉主进程vs渲染进程脚本的概念。

主进程脚本看起来像个普通的nodejs脚本

  1. const electron = require('electron');
  2. const app = electron.app;
  3. const BrowserWindow = electron.BrowserWindow;
  4. var window = null;
  5. app.on('ready', function() {
  6. window = new BrowserWindow({width: 800, height: 600});
  7. window.loadURL('https://github.com');
  8. });

渲染进程和传统的web界面一样,除了它具有使用node模块的能力:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <script>
  5. const remote = require('electron').remote;
  6. console.log(remote.app.getVersion());
  7. </script>
  8. </body>
  9. </html>

如果想运行应用,参考 Run your app

解构任务

如果你使用的是CoffeeScript或Babel,你可以使用destructuring assignment来让使用内置模块更简单:

  1. const {app, BrowserWindow} = require('electron');

然而如果你使用的是普通的JavaScript,你就需要等到Chrome支持ES6了。

使用内置模块时禁用旧样式

在版本v0.35.0之前,所有的内置模块都需要按造 require('module-name') 形式来使用,虽然它有很多弊端,我们仍然在老的应用中友好的支持它。

为了完整的禁用旧样式,你可以设置环境变量 ELECTRON_HIDE_INTERNAL_MODULES :

  1. process.env.ELECTRON_HIDE_INTERNAL_MODULES = 'true'

或者调用 hideInternalModules API:

  1. require('electron').hideInternalModules()