DEV Community

Cover image for Hoisting in JavaScript
Parwinder πŸ‘¨πŸ»β€πŸ’»
Parwinder πŸ‘¨πŸ»β€πŸ’»

Posted on • Updated on

Hoisting in JavaScript

What is hoisting?

Hoisting in JavaScript allows you to access variables and functions before they are created.

Function Hoisting

console.log(helloWorld()); // Hello World
console.log(multiplyNumbers(10, 5)); // 50

function helloWorld() {
    return "Hello World";
}

function multiplyNumbers(a, b) {
    return a * b;
}

You can see that I had used both the functions before they were declared, and JavaScript had no issues. It console logged the results as expected. It is a good practice to declare the functions prior to using them.

Variable Hoisting

console.log(age); // undefined
console.log(foo); // Reference Error: foo is not defined

var age = 10;

I was able to use the variable age before it being declared. It did log undefined, but it did not throw an error. If you compare it to the log of variable foo, you would see that the statement throws an error.

Caveat of Hoisting

Why did it not log the value of the variable age?

Hoisting supports variable and function declarations only.

So when javascript hoists variables or functions, it takes the declaration to the top of the file. It does not, however, take the definition or the value assigned. So in the example of age, it hoisted the variable but not the value assigned to it.

Due to the principle of hoisting decelerations only, you would not have been able to use the example provided in function hoisting, if I used function expressions.

console.log(helloWorld()); // helloWorld is not defined
console.log(multiplyNumbers(10, 5));

const helloWorld = function () {
    return "Hello World";
}

const multiplyNumbers = function (a, b) {
    return a * b;
}

Top comments (4)

Collapse
 
jonrandy profile image
Jon Randy πŸŽ–οΈ

Hoisting in JavaScript allows you to access variables and functions before they are created.

This is misleading. They have been created otherwise they wouldn't be accessible. They're just created first before the function body executes. Hoisting is just a convenient mental model of what is going on, but it isn't actually what is going on. It is described well here

Collapse
 
bhagatparwinder profile image
Parwinder πŸ‘¨πŸ»β€πŸ’»

When I say β€œcreated”, I’m referring to the end user looking at the source code. For them the creation has happened yet.

Internally the interpreter creates them before executing the function itself. No one is disagreeing with this.

And you are correct, it is a mental model that helps to understand this concept. The idea that the declarations are hoisted/bubbled up to the top of the source code. No one is trying to mislead.

Thanks for the feedback and linking to a more in depth article β™₯️

Collapse
 
shawnwildermuth profile image
Shawn Wildermuth

Did you mean "Declarations"?

"Hoisting supports variable and function decelerations only."

Collapse
 
bhagatparwinder profile image
Parwinder πŸ‘¨πŸ»β€πŸ’»

Well, there goes my spell checker out of the window 😭

Thanks a ton Shawn, much appreciated and I’ll update the post.