Hoisting in JS

Hoisting in JS


In JavaScript, we can access the variables and functions even before they are initialized or assigned a value.

Look at the code below:

greet(); //JavaScript
console.log(x);//Undefined
function greet(){
   console.log("JavaScript")
};
var x = 28;
Enter fullscreen mode

Exit fullscreen mode

In many other programming languages, this would result in an error. However, in JavaScript, this code runs without any error. JavaScript executes code line by line, but before execution, memory is allocated for all variables and functions. During the two phases—Memory Creation and Code Execution—the Memory Creation Phase assigns undefined to variables(x) and stores the entire function code(greet()) in memory. Here, we are trying to access greet even before it is initialized (We can access the function anywhere before it is initialized). If we remove (x = 28), it will result in an Uncaught ReferenceError: x is not defined.

console.log(greet); //ƒ greet(){console.log("JavaScript");}
console.log(x);//Uncaught ReferenceError: x is not defined
function greet(){
   console.log("JavaScript");
};
Enter fullscreen mode

Exit fullscreen mode

Hoisting is the concept of moving declarations to the top of their scope during the compile phase, before the code is executed. Declaring a variable or function means creating or defining its name so that the JavaScript engine recognizes its existence. Initialization refers to assigning a value to a declared variable or defining the code inside a function. In JavaScript, var is hoisted. However, only the declaration is hoisted, not the initialization.

greet(); //Declaring a function
var x; // Declaring a variable
console.log(x);//Undefined
function greet(){
   console.log("JavaScript")
};
x = 28;// Initializing a variable
Enter fullscreen mode

Exit fullscreen mode

greet()
var greet = () => {
   console.log("JavaScript");
 }; //Uncaught TypeError: greet is not a function
Enter fullscreen mode

Exit fullscreen mode

When we run this code, we will get an error. This will happen because, during the memory creation phase, greet will be assigned undefined, as it will be treated as a variable.

Credits to Akshay Saini.



Source link
lol

By stp2y

Leave a Reply

Your email address will not be published. Required fields are marked *

No widgets found. Go to Widget page and add the widget in Offcanvas Sidebar Widget Area.