Javascript Hoisting

In JavaScript, you can use a variable before declaring it. This is called “hoisting”. The declaration is moved to the top, so the variable is recognized even if it’s used earlier.

In JavaScript, there are two types of hoisting:

Function Hoisting: F…


This content originally appeared on DEV Community and was authored by Pranav Tech

In JavaScript, you can use a variable before declaring it. This is called "hoisting". The declaration is moved to the top, so the variable is recognized even if it's used earlier.

In JavaScript, there are two types of hoisting:

  1. Function Hoisting: Functions declared using the function keyword are "hoisted" to the top of their scope, allowing them to be called before they're defined.
  2. Variable Hoisting: Variables declared using var are also "hoisted" to the top of their scope, but only the declaration is hoisted, not the assignment.

NOTE:

  • let and const variables are not hoisted in the same way as var variables. They are still hoisted, but they are not initialized until they are declared, so trying to access them before they are declared will result in a ReferenceError.

  • Function hoisting in JavaScript only works for:
    Function declarations: Functions declared using the function keyword, like this: function myFunction() { ... }
    It does not work for:
    Function expressions: Functions assigned to a variable, like this: var myFunction = function() { ... }
    Arrow functions: Functions declared using the arrow syntax, like this: var myFunction = () => { ... }
    So, only plain function declarations are hoisted in JavaScript.

Variabel Hoisting Example:

// Using the variable before declaring it
console.log(x);  // Output: undefined

// Declaring the variable
var x = 10;

In this example, even though x is used before it's declared, the code doesn't throw an error. Instead, x is logged as undefined. This is because the variable declaration is hoisted to the top.

Function Hoisting Example:

// Calling the function before it's declared
myFunction();

// Declaring the function
function myFunction() {
console.log("Hello, world!");
}

// Output: "Hello, world!"

In this example, even though we call myFunction() before it's declared, the code still works because the function declaration is "hoisted" to the top of the scope.

then give me "Could include a quick "best practices" section" for it

Best Practices for Handling Hoisting in JavaScript

  1. Declare Variables at the Top
  2. Always declare variables at the beginning of their scope
  3. Improves code readability
  4. Prevents unexpected behavior from hoisting
function example() {
    // Recommended approach
    let x, y, z;

    // Rest of your code
}
  1. Prefer let and const Over var
  2. Use let and const for more predictable variable behavior
  3. They have block scope and aren't hoisted in the same way as var
  4. Helps prevent unintended variable access
// Recommended
let count = 10;
const MAX_SIZE = 100;

// Avoid
var unpredictableVariable;
  1. Avoid Relying on Hoisting
  2. Don't write code that depends on hoisting mechanics
  3. Declare functions and variables before using them
  4. Makes your code more explicit and easier to understand
// Good: Clear and predictable
function calculateTotal() {
    // Function logic
}

calculateTotal();

// Avoid: Relies on hoisting
calculateTotal(); // Risky

function calculateTotal() {
    // Function logic
}
  1. Use Strict Mode
  2. Enable 'use strict' to catch potential hoisting-related errors
  3. Helps identify and prevent problematic code patterns
'use strict';

// Strict mode will throw errors for certain hoisting scenarios
  1. Be Consistent with Function Declarations
  2. Stick to function declarations for better predictability
  3. Avoid mixing function declaration and expression styles
// Consistent and clear
function mainFunction() {
    function helperFunction() {
        // Logic
    }
}

Pro Tips

  • Always aim for code clarity
  • Understand hoisting, but don't rely on it as a coding technique
  • Write code that is self-explanatory and predictable


This content originally appeared on DEV Community and was authored by Pranav Tech


Print Share Comment Cite Upload Translate Updates
APA

Pranav Tech | Sciencx (2025-01-12T07:00:52+00:00) Javascript Hoisting. Retrieved from https://www.scien.cx/2025/01/12/javascript-hoisting-5/

MLA
" » Javascript Hoisting." Pranav Tech | Sciencx - Sunday January 12, 2025, https://www.scien.cx/2025/01/12/javascript-hoisting-5/
HARVARD
Pranav Tech | Sciencx Sunday January 12, 2025 » Javascript Hoisting., viewed ,<https://www.scien.cx/2025/01/12/javascript-hoisting-5/>
VANCOUVER
Pranav Tech | Sciencx - » Javascript Hoisting. [Internet]. [Accessed ]. Available from: https://www.scien.cx/2025/01/12/javascript-hoisting-5/
CHICAGO
" » Javascript Hoisting." Pranav Tech | Sciencx - Accessed . https://www.scien.cx/2025/01/12/javascript-hoisting-5/
IEEE
" » Javascript Hoisting." Pranav Tech | Sciencx [Online]. Available: https://www.scien.cx/2025/01/12/javascript-hoisting-5/. [Accessed: ]
rf:citation
» Javascript Hoisting | Pranav Tech | Sciencx | https://www.scien.cx/2025/01/12/javascript-hoisting-5/ |

Please log in to upload a file.




There are no updates yet.
Click the Upload button above to add an update.

You must be logged in to translate posts. Please log in or register.