Home > Web Front-end > JS Tutorial > let, const , var difference in Javascript?

let, const , var difference in Javascript?

WBOY
Release: 2024-08-13 19:03:51
Original
1020 people have browsed it

let, const , var difference in Javascript?

In JavaScript, let, const, and var are used to declare variables, but they are different in three ways:

1. Scope
2. Reassignment
3. Hoisting

1.Scope:

var is a functional scope means we access var variable anywhere within the function if we try access it outside function it will show error undefined
Example:-

function demo(){
  if(true){
    var n = 3;
  }
  console.log(n)
}
console.log(n) //ReferenceError: n is not defined
demo();
Copy after login

let & const are block means we can access them within the scope only otherwise it will show undefined error
Example:-

function demo(){
  if(true){
    let n = 3;
    const m = 5;
     console.log(n) // 3
     console.log(m) // 5
  }
  console.log(n) //ReferenceError: n is not defined
  console.log(m) //ReferenceError: n is not defined
}
console.log(n) //ReferenceError: n is not defined
console.log(m) //ReferenceError: n is not defined
demo();
Copy after login

2.Reassignment

  • var: Can be reassigned and redeclared within its scope.
  • let: Can be reassigned but not redeclared within its scope.
  • const: Cannot be reassigned or redeclared. The variable itself is immutable, though objects and arrays assigned to const can still be modified .

3.Hoisting

  • var is hoisted, meaning it's accessible before its declaration, but its value will be undefined until the code reaches the line where the variable is initialized.
  • let is also hoisted, but unlike var, it cannot be accessed before its declaration due to the "temporal dead zone."
  • Variables declared with const are also hoisted but must be initialized at the time of declaration and cannot be reassigned. However, if the variable is an object or array, its contents can be modified (e.g., adding or removing items from an array).
// var example
console.log(a); // undefined (due to hoisting)
var a = 10;
console.log(a); // 10

// let example
console.log(b); // ReferenceError: Cannot access 'b' before initialization
let b = 20;
console.log(b); // 20

// const example
const c = 30;
c = 40; // TypeError: Assignment to constant variable
Copy after login

The above is the detailed content of let, const , var difference in Javascript?. For more information, please follow other related articles on the PHP Chinese website!

source:dev.to
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template