Быстрый старт
Electron позволяет Вам делать приложения для рабочего стола на чистом JavaScript, предоставляя среду с богатым API. Можете представлять его как Node.js приложение, которое ориентировано для рабочего стола, а не для веб сервера.
Однако это не значит, что Electron — лишь привязка к GUI билиотекам. На деле Electron использует веб-страницы как интерфейс, так что Вы можете считать его небольшим Chroumium браузером, который контролируется с помощью JavaScript.
Главный процесс
В Electron процесс, который запускает main
из package.json
называется
главным процессом. Скрипт, который работает в главном процессе может
показывать GUI, создавая веб-страницы.
Процесс-рендерер
Так как Electron использует Chromium для показа веб-страниц, мульти-процессовая архитектура показа страниц Chromium тоже используется. Каждая веб-страница в Electron работает в своём собственном процессе, который называется процесс-рендерер.
В обычных браузерах веб-страницы обычно запускаются в "песочнице" и им недоступны реальные ресурсы компьютера. Пользователи Electron напротив могут использовать API Node.js на страницах, что допускает более низкоуровневую работу с операционной системой.
Разница между главным процессом и процессом-рендерером
Главный процесс создаёт веб-страницы используя BrowserWindow
. Каждый экземпляр
BrowserWindow
показывает веб-страницу через свой собственный процесс-рендерер.
Если экземпляр BrowserWindow
уничтожается, то и соответствующий процесс-рендерер тоже
завершается.
Главный процесс управляет всеми веб-страницами и соответствующими им процессами-редерерами. Каждый процесс-рендерер изолирован и управляет только своей веб-страницей.
На веб-страницах не позволяется вызывать нативные API, которые управляют GUI, потому что это очень опасно и может легко вызвать утечку ресурсов. Если вы хотите выполнить действия с GUI на странице, процесс-рендерер этой страницы должен "попросить" главный процесс сделать эти действия.
В Electron есть несолько способов общения между процессам. Например, модули
ipcRenderer
и ipcMain
используются
для отправки сообщений, а remote - для коммуникации в RPC стиле.
В FAQ также есть пункт о том, как разделять информацию между страницами
Первое приложение на Electron
Как правило, приложение Electron структурировано следующим образом:
your-app/
├── package.json
├── main.js
└── index.html
Формат package.json
точно такой же, как у модулей Node и скрипт, объявленый
как main
, будет выполняться при запуске вашего приложения, работая в
главном процессе. Например, Ваш package.json
может выглядеть вот так:
{
"name" : "your-app",
"version" : "0.1.0",
"main" : "main.js"
}
Заметка: Если поле main
отсутствует в package.json
, Electron попробует
загрузить index.js
.
main.js
должен создавать окно и управлять системными событиями,
типичный пример:
const electron = require('electron')
// Модуль, контролирующий основное: сам Electron.
const app = electron.app
// Модуль, создающий окно приложения.
const BrowserWindow = electron.BrowserWindow
// Удерживайте глобальное обращение к объекту окна, если Вы так не сделаете, то
// окно само закроется после того, как объект будет собран сборщиком мусора.
let mainWindow
function createWindow () {
// Создаём окно браузера
mainWindow = new BrowserWindow({width: 800, height: 600})
// и загружаем index.html приложения.
mainWindow.loadURL(`file://${__dirname}/index.html`)
// Открываем DevTools.
mainWindow.webContents.openDevTools()
// Будет выполнено, когда пользователь закроет окно
mainWindow.on('closed', function () {
// Убрать обращение на объект окна, обычно стоит хранить окна в массиве,
// если ваше приложение поддерживает несколько, сейчас стоит удалить
// соответствующий элемент.
mainWindow = null
})
}
// Этот метод будет вызван, когда Electron закончит инициализацию
// и будет готов создавать окна браузера.
// Некоторые API возможно использовать только после того, как
// это произойдёт.
app.on('ready', createWindow)
// Выйти, если все окна закрыты
app.on('window-all-closed', function () {
// На macOS приложение и его строка меню обычно остаются активными,
// пока пользователь не завершит их с помощью `Cmd + Q`.
if (process.platform !== 'darwin') {
app.quit()
}
})
app.on('activate', function () {
// На macOS приложение обычно пересоздаёт окно, когда
// пользователь кликает на его иконку в доке, если не открыто
// других окон.
if (mainWindow === null) {
createWindow()
}
})
// В этот файл Вы можете включить остальной код вашего главного процесса.
// Вы также можете разложить его по отдельным файлам и подключить с помощью require.
Наконец, index.html
, страница, которую Вы хотите показать:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Hello World!</title>
</head>
<body>
<h1>Привет, мир!</h1>
Мы используем Node <script>document.write(process.versions.node)</script>,
Chrome <script>document.write(process.versions.chrome)</script>,
и Electron <script>document.write(process.versions.electron)</script>.
</body>
</html>
Запуск вашего приложения
После того как Вы создали main.js
, index.html
и package.json
Вам скорее всего захочется
запустить приложение, чтобы проверить, что оно работает так, как надо.
electron-prebuilt
electron-prebuilt
— npm
модуль,
который содержит прекомпилированную версию Electron.
Если вы установили Electron глобально через npm
, то Вам нужно будет всего лишь
запустить сдедующее в папке вашего проекта:
electron .
Если Вы установили Electron локально, то выполните это:
./node_modules/.bin/electron .
Исполняемые файлы Electron, скачанные вручную
Если Вы скачали Electron вручную, то Вы можете использовать исполняемые файлы прямо в папке вашего проекта.
Windows
$ .\electron\electron.exe your-app\
Linux
$ ./electron/electron your-app/
macOS
$ ./Electron.app/Contents/MacOS/Electron your-app/
Electron.app
— часть реализного пакета Electron, Вы можете скачать его
тут.
Запустить как дистрибутив
Когда Вы закончили написание вашего приложения, Вы можете создать дистрибутив, следуя инструкциям отсюда и затем запустить полученное приложение.
Попробуйте этот пример
Скопируйте и запустите этот обучающий код, используя репозиторий atom/electron-quick-start
Заметка: Для запуска требуется Git и Node.js (который включает в себя npm).
# Клонируем репозиторий
$ git clone https://github.com/electron/electron-quick-start
# Переходим в папку скачанного репозитория
$ cd electron-quick-start
# Устанавливаем зависимости и запускаем
$ npm install && npm start