How to Create an App with Electron and Node.js

Electron combines Node.js, Chromium, and a large library of natively implemented APIs to allow developers to build powerful desktop applications. 

In this tutorial, you'll learn how to create an Electron app, run it, and package it on Windows, Mac OS, and Linux environments. Let's get started!

Step 1: Install Node.js

Make sure you have the latest stable version of Node.js installed on your computer. If you don't have it, you can download it from their official website.

Step 2: Create A New Project

Open your terminal or command prompt and navigate to the directory where you'd like to create your Electron project, then run these commands:

mkdir my-app
cd my-app
my-app can be changed to any project name of your liking.

Step 3: Initialize the Node.js Project

In the project directory, initialize the new Node.js project by running the following command:

npm init -y

Step 4: Install Electron

To install Electron as a development dependency within Node.js, you'll need to run the following command:

npm install electron --save-dev

Step 5: Create the Main Script

Within your project directory, create a new file named main.js. This will be your main project file and is required to execute a desktop instance. Add this code to the file:

const { app, BrowserWindow } = require("electron")

function createWindow() {
const mainWindow = new BrowserWindow({
width: 800,
height: 600,
webPreferences: {
nodeIntegration: true
}
})

mainWindow.loadFile("index.html")
}

app.whenReady().then(() => {
createWindow();

app.on("activate", function() {
if (BrowserWindow.getAllWindows().length === 0) {
createWindow()
}
})
})

app.on("window-all-closed", function() {
if (process.platform !== "darwin") {
app.quit()
}
})

When the application fully launches, the createWindow() method creates a new desktop window with a size of 800x600 pixels, loading the index.html file that we'll create shortly with the mainWindow.loadFile() method.

The window-all-closed event listener shuts down the application when all windows are closed as long as the user is not using the Darwin platform.

Step 6: Create the HTML File

For the HTML file, create a file named index.html in your project's root directory, and add the following code to this file:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>Electron Application</title>
</head>
<body>
<h1>Hello There!</h1>
<p>This is my first Electron application.</p>
</body<>
</html>

Step 7: Update the package.json Configuration File

Open the package.json file in your project's root directory and add the following code snippet:

"scripts": {
"start": "electron ."
}

Step 8: Start the Electron App

Now you're ready to run the Electron app as a desktop application! The following command prompt will execute the application for you:

npm start

If everything is set up correctly, a new desktop window should launch with your application!

Create Desktop App Executable Files

If you want to only generate the executable files for your Electron app, you can do so by installing Electron Packager with the following command:

npm install electron-packager --save-dev

Now, you can create executable files for your Electron app and package your application files.

Here is the command to create Windows executable files:

electron-packager . [my-app] --platform=win32 --icon=./build/icon.ico --overwrite

Here is the command to create Mac OS executable files:

electron-packager . [my-app] --platform=darwin --icon=./build/icon.icns

And here is the command to create Linux executable files:

electron-packager . [my-app] --platform=linux --icon=./build/icon.png
Remember my-app is the name of your Electron application, so make sure to change it accordingly before running the commands.
Also, note that you will receive an error message if the desktop application files already exist. You can add the optional --overwrite flag to overwrite any existing files with a fresh copy of the application.

Create a Desktop Icon for the Electron App

There are three different desktop icons you'll need to create, one for each operating system. Here are the formats and sizes required for each:

Conclusion

That's it! You've successfully installed Electron and created your first desktop application! You can now build upon its foundation to create more complex desktop applications using Electron.

Written by: Josh Rowe

Created: July 10, 2023