Declaring and Using Variables in JavaScript – var, let, const, and Scope

In JavaScript, variables are containers for values and must be declared before use. This article explores the three main declaration forms — var, let, and const — and their differences in scope, mutability, and appropriate use cases. It also covers variable declarations in functions and catch blocks, helping developers write clearer and more maintainable code.

JavaScriptvariablesletconst

~3 min read • Updated Oct 14, 2025

Introduction


In JavaScript programs, values can appear as literals or be stored in variables. Think of variables as containers for values. To use a variable, it must first be declared. JavaScript offers several ways to declare variables, each with its own behavior and scope rules.


Declaring with var


The var keyword declares a variable in the function or global scope:


var name = "Kyle";
var age;

Variables declared with var are accessible throughout the function or file, even outside of blocks like if.


Declaring with let


let is similar to var but introduces block scope, meaning the variable is only accessible within the block it’s declared in:


var adult = true;
if (adult) {
  var name = "Kyle";
  let age = 39;
  console.log("Shhh, this is a secret!");
}
console.log(name); // Kyle
console.log(age);  // Error!

age is block-scoped to the if block, while name is not.


Block Scope and Its Benefits


Using let helps limit the visibility of variables, reducing the risk of name collisions. var is still useful when broader access is needed. Choosing between them depends on the context.


Declaring with const


const is like let but with an added restriction: it must be initialized at declaration and cannot be reassigned:


const myBirthday = true;
let age = 39;
if (myBirthday) {
  age = age + 1;       // OK
  myBirthday = false;  // Error!
}

const prevents reassignment but not mutation. Using const with objects can be misleading:


const actors = ["Morgan Freeman", "Jennifer Aniston"];
actors[2] = "Tom Cruise"; // Allowed :(
actors = [];              // Error!

The best use of const is for simple primitive values with meaningful names, like myBirthday instead of true.


Tip: Use const Safely


If you use const only for primitive values, you avoid confusion between reassignment (disallowed) and mutation (allowed). This is the safest way to use const.


Declaring Variables in Functions


Functions also declare variables. Parameters behave like internal variables:


function hello(name) {
  console.log(`Hello, ${name}.`);
}
hello("Kyle"); // Hello, Kyle

hello is declared in the outer scope, while name is scoped to the function body.


Declaring Variables in catch Blocks


Variables can also be declared in catch clauses. These are block-scoped, similar to let:


try {
  someError();
}
catch (err) {
  console.log(err);
}

err exists only within the catch block.


Conclusion


JavaScript variables can be declared using var, let, or const, each with distinct scope and mutability rules. Understanding these differences helps you write cleaner, more reliable code. Variables can also be declared in functions and catch blocks, making scope awareness essential for maintainable programming.


Written & researched by Dr. Shahin Siami