These have been adapted from the style guidelines for coding in Electron.
You can run yarn lint
to show any style issues detected by eslint
.
- End files with a newline.
- Using a plain
return
when returning explicitly at the end of a function.- Not
return null
,return undefined
,null
orundefined
- Not
- run
yarn format
to rewrite all files in the standard format - run
yarn format:head
to rewrite files from your last commit
- Write remark markdown style.
- Write standard JavaScript style.
- File names should be concatenated with
-
instead of_
, e.g.file-name.js
rather thanfile_name.js
, because in github/atom module names are usually in themodule-name
form. This rule only applies to.js
files. - Use newer ES6/ES2015 syntax where appropriate
const
for requires and other constants. If the value is a primitive, use uppercase naming (egconst NUMBER_OF_RETRIES = 5
).let
for defining variables- Arrow functions
instead of
function () { }
- Template literals
instead of string concatenation using
+
Electron APIs uses the same capitalization scheme as Node.js:
- When the module itself is a class like
BrowserWindow
, usePascalCase
. - When the module is a set of APIs, like
globalShortcut
, usecamelCase
. - When the API is a property of object, and it is complex enough to be in a
separate chapter like
win.webContents
, usemixedCase
. - For other non-module APIs, use natural titles, like
<webview> Tag
orProcess Object
.
When creating a new API, it is preferred to use getters and setters instead of
jQuery's one-function style. For example, .getText()
and .setText(text)
are preferred to .text([text])
. There is a
discussion on this.