avatar

Lexical scope

The lexical scope is the scope of a variable or function based on where it is defined in the source code. The scope is determined by the placement of variables and functions in the code, and it remains the same throughout the execution of the program.

const a = 2

function foo() {
  console.log(a)
}

function bar() {
  const a = 3

  foo()
}

foo() // 2
bar() // 2

Lexical scope isn't like this value, this value can be changed in the runtime.

var a = 2

function foo() {
  console.log(this.a)
}

function bar() {
  var a = 3

  foo.call({ a })
}

foo() // 2
bar() // 3