打造你的第一个 Electron 应用

    这不意味着 Electron 是某个图形用户界面(GUI)库的 JavaScript 版本。 相反,Electron 使用 web 页面作为它的 GUI,所以你能把它看作成一个被 JavaScript 控制的,精简版的 Chromium 浏览器。

    注意: 获取该示例的代码仓库: 立即下载并运行

    从开发的角度来看, Electron application 本质上是一个 Node. js 应用程序。 与 Node.js 模块相同,应用的入口是 文件。 一个最基本的 Electron 应用一般来说会有如下的目录结构:

    为你的新Electron应用创建一个新的空文件夹。 打开你的命令行工具,然后从该文件夹运行npm init

    1. npm init

    npm 会帮助你创建一个基本的 package.json 文件。 其中的 main 字段所表示的脚本为应用的启动脚本,它将会在主进程中执行。 如下片段是一个 package.json 的示例:

    1. {
    2. "name": "your-app",
    3. "version": "0.1.0",
    4. "main": "main.js"
    5. }

    By default, npm start would run the main script with Node.js. in order to make it run with Electron, you can add a start script:

    现在,您需要安装electron。 我们推荐的安装方法是把它作为您 app 中的开发依赖项,这使您可以在不同的 app 中使用不同的 Electron 版本。 在您的app所在文件夹中运行下面的命令:

    1. npm install --save-dev electron

    除此之外,也有其他安装 Electron 的途径。 请咨询来了解如何用代理、镜像和自定义缓存。

    Electron apps 使用JavaScript开发,其工作原理和方法与Node.js 开发相同。 electron模块包含了Electron提供的所有API和功能,引入方法和普通Node.js模块一样:

    1. const electron = require('electron')

    electron 模块所提供的功能都是通过命名空间暴露出来的。 比如说: electron.app负责管理Electron 应用程序的生命周期, electron.BrowserWindow类负责创建窗口。 下面是一个简单的main.js文件,它将在应用程序准备就绪后打开一个窗口:

    1. const { app, BrowserWindow } = require('electron')
    2. function createWindow () {
    3. // 创建浏览器窗口
    4. width: 800,
    5. height: 600,
    6. webPreferences: {
    7. nodeIntegration: true
    8. }
    9. // 并且为你的应用加载index.html
    10. win.loadFile('index.html')
    11. // 打开开发者工具
    12. win.webContents.openDevTools()
    13. }
    14. // Electron会在初始化完成并且准备好创建浏览器窗口时调用这个方法
    15. // 部分 API 在 ready 事件触发后才能使用。
    16. app.whenReady().then(createWindow)
    17. // Quit when all windows are closed, except on macOS. There, it's common
    18. // for applications and their menu bar to stay active until the user quits
    19. // explicitly with Cmd + Q.
    20. app.on('window-all-closed', () => {
    21. if (process.platform !== 'darwin') {
    22. app.quit()
    23. }
    24. })
    25. app.on('activate', () => {
    26. // dock icon is clicked and there are no other windows open.
    27. if (BrowserWindow.getAllWindows().length === 0) {
    28. createWindow()
    29. }
    30. })
    31. // 您可以把应用程序其他的流程写在在此文件中
    32. // 代码 也可以拆分成几个文件,然后用 require 导入。

    最后,创建你想展示的 index.html

    1. <!DOCTYPE html>
    2. <html>
    3. <head>
    4. <meta charset="UTF-8">
    5. <title>Hello World!</title>
    6. <!-- https://electronjs.org/docs/tutorial/security#csp-meta-tag -->
    7. <meta http-equiv="Content-Security-Policy" content="script-src 'self' 'unsafe-inline';" />
    8. </head>
    9. <body>
    10. <h1>Hello World!</h1>
    11. We are using node <script>document.write(process.versions.node)</script>,
    12. Chrome <script>document.write(process.versions.chrome)</script>,
    13. and Electron <script>document.write(process.versions.electron)</script>.
    14. </body>

    在创建并初始化完成 main.jsindex.htmlpackage.json之后,您就可以在当前工程的根目录执行 npm start 命令来启动刚刚编写好的Electron程序了。

    复制并运行这个库

    注意:本例需要 和 npm 来运行。

    启动开发过程的有关模板文件和工具列表, 请参阅模板文件和 CLI 文档 。