Skip to content
This repository has been archived by the owner on Jul 3, 2020. It is now read-only.

Latest commit

 

History

History
71 lines (52 loc) · 2 KB

code-style-exceptions.md

File metadata and controls

71 lines (52 loc) · 2 KB

Code Style Exceptions

The JavaScript code adheres to the style guide found here, but with some exceptions:

No ES6 Modules

V8 support for native ES6 modules is under development, so for now use require like you would in Node. All other ES6 features (classes, destructuring, default parameters, etc.) can be used freely.

Using for-of and for-in

You're free to use for-of and for-in as necessary, however it's better to use for (let value of object) for values and for (let key of Object.keys(object)) for keys. You can still use for-in, just be sure you know the catch when using it.

Using 'dangling' underscores

You can use 'dangling' underscores to denote a private member on an object or class. Some APIs were written before this style was adopted which use underscores for private members and probably won't be changed for compatibility. However, for any new APIs, it'd be preferred to use a Symbol instead, like:

const somePrivateVarName = Symbol('somePrivateVarName');

class Demo {
  constructor() {
    this[somePrivateVarName] = 'my value';
  }
  getMyPrivateVar() {
    return this[somePrivateVarName];
  }
}

Using get and set

You can (and should) use ES6 get and set in new APIs, it's already used in various runtime.js APIs.

Assigning to functions parameters

You cannot reassign functions parameters, but you can assign to properties of function parameters.

// yes
const demo = (myObject) => {
  myObject.someProperty = 'my value';
  // ...
}

// no
const demo = (myObject) => {
  myObject = {
    someProperty: 'my value'
  };
  // ...
}

Wrapping an IIFE

The invocation should be outside the parentheses, not inside.

// yes
(function() {
  // ...
})();

// no
(function() {

}());