go backBack to blog

JS Scopes: A Journey Through the Realm of Variable Access

Published on Jan 22 2023

Last updated on May 03 2023

Photo by Matthijs van Schuppen on Unsplash
No translation available.
Add translation

To explore the landscape of JavaScript safely, it is crucial to understand the concept of scopes. Scopes are the territories in which our variables live and thrive. Today, we'll journey through this realm, exploring the different types of scopes and understanding how to wield them effectively.

What is Scope in JavaScript?

The scope of a variable determines where it can be accessed and used within your code. There are three types of scope in JavaScript:

  • Global Scope

  • Function (Local) Scope

  • Block Scope

Let's dive into each of these and learn how they function!

1. Global Scope

Variables declared in the global scope can be accessed from anywhere in your code. Think of global scope as the open wilderness where all functions and blocks can freely access the variables roaming about.

To declare a variable in the global scope, you simply need to define it outside of any function or block.

globarScope.js

let globalVar = "I'm a global variable!";
function showGlobalVar() {
console.log(globalVar);
}
showGlobalVar(); // Output: "I'm a global variable!"

However, exercise caution when using global variables. Overusing them can result in unintended consequences, as they can be accessed and modified anywhere in your code. It's best to keep variables as local as possible.

2. Function (Local) Scope

Function scope, also known as local scope, confines variables within the boundaries of a function. These variables can only be accessed within the function they are declared in, effectively keeping them hidden from the outside world.

functionScope.js

function localScopeExample() {
let localVar = "I'm a local variable!";
console.log(localVar);
}
localScopeExample(); // Output: "I'm a local variable!"
console.log(localVar); // ReferenceError: localVar is not defined

In the example above, localVar is only accessible within the localScopeExample function. Attempting to access it outside of this function results in a ReferenceError.

3. Block Scope

Block scope is a more recent addition to JavaScript, introduced with the let and const keywords in ES6 (ECMAScript 2015). Variables declared with let or const are confined to the block they are declared in, such as a loop or an if statement.

blockScope.js

if (true) {
let blockVar = "I'm a block-scoped variable!";
console.log(blockVar);
}
console.log(blockVar); // ReferenceError: blockVar is not defined

In this example, blockVar is only accessible within the if statement. Attempting to access it outside of this block results in a ReferenceError.

Scope Nesting

Scopes can be nested within one another, creating a hierarchy of variable accessibility. Inner scopes can access variables from outer scopes, but the reverse is not true.

scopeNesting.js

let outerVar = "I'm an outer variable!";
function outerFunction() {
let innerVar = "I'm an inner variable!";
function innerFunction() {
console.log(outerVar); // Output: "I'm an outer variable!"
console.log(innerVar); // Output: "I'm an inner variable!"
}
innerFunction();
}
outerFunction();

In this example, the innerFunction can access both outerVar and innerVar, as they are in the outer scopes. However, if we try to access innerVar from outerFunction or the global scope, we'll encounter a ReferenceError.

scopeReferenceError.js

console.log(innerVar); // ReferenceError: innerVar is not defined
function anotherFunction() {
console.log(innerVar); // ReferenceError: innerVar is not defined
}

Hoisting: A Quirky Side Effect

Hoisting is a JavaScript mechanism that moves variable and function declarations to the top of their respective scopes during the compilation phase. This can lead to some unexpected behavior, especially when it comes to variables declared with var.

Here's an example of how hoisting can cause confusion:

scopeHoisting.js

console.log(hoistedVar); // Output: undefined
var hoistedVar = "I'm a hoisted variable!";

Despite hoistedVar being declared and initialized after the console.log statement, the code doesn't throw a ReferenceError. This is because the variable declaration is hoisted to the top of the scope, while the assignment stays in place. The code is interpreted like this:

scopeHoisting.js

var hoistedVar;
console.log(hoistedVar); // Output: undefined
hoistedVar = "I'm a hoisted variable!";

To avoid hoisting-related issues, it's a good practice to use let and const instead of var, as they have block scope and are not hoisted in the same way.

Conclusion

Understanding scopes in JavaScript is essential for managing variable accessibility and avoiding common pitfalls. Remember these key points:

  1. Global scope is accessible from anywhere, but use it sparingly.

  2. Function (local) scope confines variables within a function.

  3. Block scope, introduced with let and const, confines variables within a block.

  4. Inner scopes can access variables from outer scopes, but not vice versa.

  5. Be aware of hoisting when using var, and consider using let or const instead.

With these concepts in mind, you're well-equipped to navigate the realm of JavaScript safe and sound.

Tags:
data structures
javascript
My portrait picture

Written by Alissa Nguyen

Alissa Nguyen is a software engineer with main focus is on building better software with latest technologies and frameworks such as Remix, React, and TailwindCSS. She is currently working on some side projects, exploring her hobbies, and living with her two kitties.

Learn more about me


If you found this article helpful.

You will love these ones as well.

  • Photo by Huy Phan on Unsplash
    May 04 2023 — 5 min readUnderstanding Fetch API and AJAX
    #javascript
  • Image by Karine Avetisyan on Unsplash
    Jan 19 2023 — 5 min readInheritance and Prototypes in JavaScript
    #front-end#javascript

  • Built and designed by Alissa Nguyen a.k.a Tam Nguyen.

    Copyright © 2025 All Rights Reserved.