No description
Find a file
Thiago de Arruda 1709b8e39d Fix sandbox crash when opening a background tab
When a link is clicked with the middle mouse button, chrome opens a window with
"background-tab" disposition. This is not currently handled in sandbox mode,
causing an api::WebContents to leak leading to eventual crash(since it has no
wrapper).

Also fix the event handler for "-add-new-contents" by having it call
`event.preventDefault()` when the window creation should be cancelled.
2017-08-15 09:55:39 -03:00
atom Bump v1.7.6 2017-08-09 15:28:55 -04:00
brightray Rollback debug mode changes 2017-08-07 15:54:44 -04:00
chromium_src Ensure DesktopCapturers are destroyed when no longer needed. 2017-08-04 15:06:58 -07:00
default_app Extract script tags to renderer.js file 2017-04-25 08:27:57 -07:00
docs Merge pull request #10253 from electron/improvements-for-libcc-development 2017-08-15 19:40:06 +09:00
docs-translations Create keyboard-shortcuts 2017-07-30 22:31:23 +08:00
lib Fix sandbox crash when opening a background tab 2017-08-15 09:55:39 -03:00
npm remove prebuilt readme in favor of top-level readme 2017-08-08 10:20:30 -07:00
script Merge pull request #10253 from electron/improvements-for-libcc-development 2017-08-15 19:40:06 +09:00
spec Merge pull request #10160 from liusy182/liusy182-10128-asar 2017-08-07 21:42:15 -04:00
tools Remove runas and code no longer using it 2017-05-30 08:49:54 -07:00
vendor Improve development workflow with built libchromiumcontent 2017-08-15 05:40:22 -03:00
.clang-format Add clang-format config file. 2016-10-04 22:42:49 +02:00
.gitignore Improve development workflow with built libchromiumcontent 2017-08-15 05:40:22 -03:00
.gitmodules Move brightray submodules to root vendor 2017-05-10 13:27:22 -07:00
.node-version Bump Node.JS version in .node-version 2017-05-31 10:06:38 +02:00
.travis.yml Fix No module named google_compute_engine error 2017-07-26 14:18:55 -07:00
appveyor.yml Fix typo 2017-07-11 10:55:59 +08:00
CODE_OF_CONDUCT.md 📝 Update to v1.4 of the Code of Conduct 2016-05-05 13:48:44 -07:00
common.gypi atom-shell -> electron in node_release_urlbase 2017-05-17 14:58:09 -07:00
CONTRIBUTING.md atom@github.com -> electron@github.com 2017-06-19 09:33:20 -07:00
electron.gyp Bump v1.7.6 2017-08-09 15:28:55 -04:00
features.gypi Add enable_osr build flag 2017-06-28 18:58:52 +02:00
filenames.gypi Add enable_osr build flag 2017-06-28 18:58:52 +02:00
ISSUE_TEMPLATE.md Incorporate feedback 2017-03-06 09:48:11 -08:00
LICENSE Update copyright year in LICENSE file 2017-01-02 21:19:38 -08:00
package.json Revert "remove no-op preinstall script" 2017-08-14 11:33:32 -07:00
README.md restore links to translated READMEs 2017-08-08 10:55:09 -07:00
SECURITY.md Add SECURITY.md 2017-01-30 10:49:17 -08:00
toolchain.gypi Link with correct targets in toolchain.gypi 2017-05-23 16:30:07 +09:00

Electron Logo

Travis Build Status AppVeyor Build Status devDependency Status Join the Electron Community on Slack

📝 Available Translations: Korean | Simplified Chinese | Brazilian Portuguese | Traditional Chinese | Spanish | Turkish | German

The Electron framework lets you write cross-platform desktop applications using JavaScript, HTML and CSS. It is based on Node.js and Chromium and is used by the Atom editor and many other apps.

Follow @ElectronJS on Twitter for important announcements.

This project adheres to the Contributor Covenant code of conduct. By participating, you are expected to uphold this code. Please report unacceptable behavior to electron@github.com.

Installation

To install prebuilt Electron binaries, use npm. The preferred method is to install Electron as a development dependency in your app:

npm install electron --save-dev --save-exact

The --save-exact flag is recommended as Electron does not follow semantic versioning. For info on how to manage Electron versions in your apps, see Electron versioning.

For more installation options and troubleshooting tips, see installation.

Quick Start

Clone and run the electron/electron-quick-start repository to see a minimal Electron app in action:

git clone https://github.com/electron/electron-quick-start
cd electron-quick-start
npm install
npm start

Resources for Learning Electron

Programmatic usage

Most people use Electron from the command line, but if you require electron inside your Node app (not your Electron app) it will return the file path to the binary. Use this to spawn Electron from Node scripts:

const electron = require('electron')
const proc = require('child_process')

// will print something similar to /Users/maf/.../Electron
console.log(electron)

// spawn Electron
const child = proc.spawn(electron)

Mirrors

Documentation Translations

Community

You can ask questions and interact with the community in the following locations:

Check out awesome-electron for a community maintained list of useful example apps, tools and resources.

License

MIT

When using the Electron or other GitHub logos, be sure to follow the GitHub logo guidelines.