JavaScript: Semicolon Rules

By Xah Lee. Date: . Last updated: .

JavaScript syntax is very complex, such that semicolon can sometimes be omitted, sometimes not, and there is no simple rule for programer to remember when it can be omitted.

Rule for Omitting Semicolon Style

Do not add semicolon, except:

A line should never start with left parenthesis () nor left square bracket []. If a line starts with parenthesis or square bracket, add a semicolon in the beginning of line (or end of previous line).

Rule for Always Using Semicolon Style

ALWAYS add semicolon at end of assignment or statement.

A redundant semicolon is a empty statement. Extra semicolon won't hurt.

Advantage of Omitting Semicolon

Disadvantage of Omitting Semicolon

Use Automatic Formatting Tool

Use deno, created by Ryan Dahl, also is the creator of node.js

deno fmt filename

deno adds semicolon.

When Do You Need Semicolon by JavaScript Grammar?

Suppose if we can turn off the JavaScript spec's Automatic Semicolon Insertion, then, when do we need a semicolon?

The full spec is fairly complex.

js semicolon rule 2022-07-29 jVk5N
js spec on semicolon, 2022-07-29. []

Using Semicolon in Practice

Here is code examples using semicolon.

Variable Assignment

Always use semicolon at end of variable assignment.

const x = 4; // semicolon

const y = {p1:1, p2:2}; // semicolon

const f = function() { return 3; }; // semicolon

Function Declaration

For function declarations, no need semicolon.

// function declaration
function f1() {
    // ...
} // semicolon not required here

Last Statement Inside a Function Body

Last statement inside a function body should have a semicolon.

return statement should have a semicolon.

function ff() {
    return 3; // ← semicolon is technically required here

No Multi-Line Return Statement

Never have a return statement by itself on a line.

// bad
function ff() {

// this is bad. JS will add a semicolon at end of return.
// so the function will just return undefined

console.log(ff()); // undefined

Function Call

A function call, returns a expression.

// function call

(function () {
    return 3;
})(); // better add semicolon here

Example of Bad Omitted Semicolon

// you intended to assign the first function, and eval the second

// js compiler tried to feed the second function as arg to your first function

const f = function() {
    return 3;
} // bad semicolon omission

(function() {
    return 4;

// compiler error

// /home/joe/test.js:7
// })();
//   ^

// TypeError: (intermediate value)(...) is not a function
//     at Object.<anonymous> (/home/joe/test.js:7:3)
//     at Module._compile (module.js:434:26)
//     at Object.Module._extensions..js (module.js:452:10)
//     at Module.load (module.js:355:32)
//     at Function.Module._load (module.js:310:12)
//     at Function.Module.runMain (module.js:475:10)
//     at startup (node.js:117:18)
//     at node.js:951:3
JavaScript in Depth