Skip to content

Latest commit

 

History

History
125 lines (85 loc) · 3.08 KB

File metadata and controls

125 lines (85 loc) · 3.08 KB

JavaScript style guide

Files

JavaScript files have the same name as the component's folder name. Test files have a .test suffix placed before the file extension.

checkboxes
├── checkboxes.js
└── checkboxes.test.js

Skeleton

import { nodeListForEach } from '../vendor/common'

function Checkboxes ($module) {
  // code goes here
}

Checkboxes.prototype.init = function () {
  // code goes here
}

export default Checkboxes

Comments

Use /** ... */ for multi-line comments. Include a description, and specify types and values for all parameters and return values.

/**
* Get the nearest ancestor element of a node that matches a given tag name
* @param {object} node element
* @param {string} match tag name (e.g. div)
* @return {object} ancestor element
*/

function (node, match) {
  // code goes here
  return ancestor
}

Use // for single-line comments. Place single-line comments on a new line above the subject of the comment.

Use // FIXME: to annotate problems.

Use // TODO: to annotate solutions to problems.

Constructors and methods

Use the prototype design pattern to structure your code.

Create a constructor and define any variables that the object needs.

function Checkboxes ($module) {
  // code goes here
}

Assign methods to the prototype object. Do not overwrite the prototype with a new object as this makes inheritance impossible.

// bad
Checkboxes.prototype = {
  init: function () {
    // code goes here
  }
}

// good
Checkboxes.prototype.init = function () {
  // code goes here
}

When initialising an object, use the new keyword.

// bad
var myCheckbox = Checkbox().init()

// good
var myCheckbox = new Checkbox().init()

Modules

Use ES6 modules (import/export) over a non-standard module system. You can always transpile to your preferred module system.

import { nodeListForEach } from '../vendor/common'
// code goes here
export default Checkboxes

Avoid using wildcard (import * as nodeListForEach) imports.

Use default export over named export.

Polyfilling

If you need to support older browsers, import the necessary polyfills and they will be added to the environment when the feature is not supported.

For example, if you want to polyfill addEventListener for IE8, import the Event polyfills.

import '../vendor/polyfills/Event'

If you need polyfills for features that are not yet included in this project, please see the following guide on how to add polyfills.

Formatting and linting

GOV.UK Frontend uses standardjs, an opinionated JavaScript linter. All JavaScript files follow its conventions, and it runs on CI to ensure that new pull requests are in line with them.

The standard docs have a complete list of rules and some reasoning behind them.

Read more about running standard manually or in your editor.

See also testing and linting.