let and const were introduced in the ES6 version of Javascript. Which enables the variable shadowing.
Let’s understand more about variable shadowing using an example:
data:image/s3,"s3://crabby-images/0ae52/0ae5265559556737984b1214fee2fe3e56fa7ef9" alt="Javascript: Variable Shadowing let and const were introduced in the ES6 version of Javascript. Which enables the variable shadowing."
In the above example the variable a is shadowed inside the if block. The value of variable a is temporarily changed inside the if block and that change is only valid inside that block.
Outside the if block the value of variable a is the same old variable that is given in line 5.
Variable Shadowing
- var can be shadowed by let (refer 1 in image below)
- let cannot be shadowed by var , it is called illegal shadowing [throws error : variable already defined] – (refer 2 in the image below)
data:image/s3,"s3://crabby-images/953ce/953ceffc9b21ed1c04c646d52add837bce5e3c56" alt=""