The Let Keyword

·

3 min read

The Let Keyword

The let keyword declares variables that are limited to the scope of block statements or expressions where it is used. It is used to declare block-scoped variables that have a value parameter which is optional. They cannot be redeclared and must be declared first before use. The let keyword was introduced in ES6 (2015).

let name1 [= value1], name2 [= value2] … nameN [= valueN];

Parameters nameN: It is the name of the variable

valueN (Optional): It is the value that is to be assigned to the variable

Variables that are declared with let cannot be redeclared, they will throw a Syntax error

SyntaxError: 'variableName' has already been declared
let user = "John Carter";

let user = 5;

// SyntaxError: 'user' has already been declared

Before ES6 (2015), JavaScript had only global scope and function scope. ES6 introduced two keywords, let & const, having block scope.

The body in between two curly braces {...} is called block scope. The let & const variables declared inside of {...} cannot be accessed from outside.

{
  let id = 1;
}
// id can NOT be used here

Now as we know that let is a block-scoped variable so its value would not affect variables declared outside of the block with the same name.

let color = “Black”;
// Here color is Black

{
    let color = “Red”;
    // Here color is Red
}

// Here color is Black

JavaScript Hoisting refers to the process whereby the interpreter appears to move the declaration of functions, variables, or classes to the top of their scope, prior to the execution of the code. Hoisting allows functions to be safely used in code before they are declared.

Variables defined with let are hoisted to the top of the block, but not initialized. Meaning: Using a let variable before it is declared will result in a ReferenceError:

color = "Black";
let color = "Red";

ReferenceError: Cannot access 'color' before initialization

let is a signal that the variable may be reassigned, such as a counter in a loop, or a value swap in an algorithm. It also signals that the variable will be used only in the block it's defined in, which is not always the entire containing function.


That's all for this article, hope you learned something. Thanks for reading, catch you later.

You can also buy me a coffee that would help me grow as a frontend developer :)

Buy Me A Coffee