
Modern JavaScript with Let Declaration
Block-Scoped Variables in ES6
Catalog
Click on this table of contents to jump to the corresponding section
The let keyword was introduced in ES6 (2015)
Variables declared with let have Block Scope
Variables declared with let must be Declared before use
Variables declared with let cannot be Redeclared in the same scope
Block Scope
Before ES6 (2015), JavaScript did not have Block Scope. JavaScript had Global Scope and Function Scope. ES6 introduced the two new JavaScript keywords: let and const. These two keywords provided Block Scope in JavaScript.
Example: Variables declared inside a { } block cannot be accessed from outside the block:
Global Scope
Variables declared with the var always have Global Scope. Variables declared with the var keyword can NOT have block scope:
Example: Variables declared with var inside a { } block can be accessed from outside the block:
Cannot be Redeclared
Variables defined with let can not be redeclared. You can not accidentally redeclare a variable declared with let:
Variables defined with varcan be redeclared.
Redeclaring Variables
Redeclaring a variable using the var keyword can impose problems. Redeclaring a variable inside a block will also redeclare the variable outside the block:
Redeclaring a variable using the let keyword can solve this problem. Redeclaring a variable inside a block will not redeclare the variable outside the block:
Difference Between var, let and const
| Scope | Redeclare | Reassign | Hoisted | Binds this | |
|---|---|---|---|---|---|
| var | No | Yes | Yes | Yes | Yes |
| let | Yes | No | Yes | No | No |
| const | Yes | No | No | No | No |
What is Good?
- let and const have block scope.
- let and const can not be redeclared.
- let and const must be declared before use.
- let and const does not bind to this.
- let and const are not hoisted.
What is Not Good?
- var does not have to be declared.
- var is hoisted.
- var binds to this.
Browser Support
The let and const keywords are not supported in Internet Explorer 11 or earlier. The following table defines the first browser versions with full support:
| Chrome 49 | Edge 12 | Firefox 36 | Safari 11 | Opera 36 |
|---|---|---|---|---|
| Mar, 2016 | Jul, 2015 | Jan, 2015 | Sep, 2017 | Mar, 2016 |
Redeclaring
Redeclaring a JavaScript variable with var is allowed anywhere in a program:
With let, redeclaring a variable in the same block is NOT allowed:
Redeclaring a variable with let, in another block, IS allowed:
Let Hoisting
Variables defined with var are hoisted to the top and can be initialized at any time.
Meaning: You can use the variable before it is declared:
If you want to learn more about hoisting, study the chapter JavaScript Hoisting. Variables defined with let are also hoisted to the top of the block, but not initialized.
Meaning: Using a let variable before it is declared will result in a “ReferenceError”:
Lily and 4 people like this
Prev Post
Space The Final Frontier
Next Post
Telescopes 101
0 Comments
Leave a Reply
Recent Post

SMOTE for Imbalanced Classification with Python
12:28:00 16/05/2026

CLAHE Histogram Equalization with OpenCV: A Python Guide
12:06:00 16/05/2026

Histogram Equalization in Digital Image Processing
10:56:00 16/05/2026

Gaussian Noise Explained: What It Is and How It Works
10:36:00 16/05/2026

Python Image Blurring with OpenCV: Gaussian, Median & Bilateral Filter Guide
09:59:00 16/05/2026
Related Topics
Feeds
Don't miss what's next 👋
Enjoyed this content? Leave your email to get notified when we publish new insights, tutorials, and updates — no spam, ever.

