IIFE in JavaScript
An Immediately-Invoked Function Expression (IIFE) is a JavaScript design pattern that involves defining a function and then immediately executing it. It's a way to create a self-contained scope for your code, preventing variable leaks into the global scope, and it's commonly used in scenarios where you want to encapsulate logic, avoid naming conflicts, or perform one-time setup tasks.
- Function Declaration: (function() { ... }) defines an anonymous function enclosed in parentheses. This is important because in JavaScript, an expression is expected after the ( symbol, and a function declaration is a statement. Wrapping it in parentheses makes it an expression.
- Invocation: The final pair of parentheses at the end () immediately invokes the function. This means the code within the function block is executed immediately after its creation.
Basic IIFE
Encapsulation
In this example, the IIFE creates a new scope, encapsulating the insideVariable and preventing it from leaking into the outer scope.
Passing Parameters
Returning Values
In this example, the IIFE calculates the sum of two numbers and immediately returns the result.
Module Pattern
This example demonstrates the module pattern using an IIFE to create a counter with private state.
Conclusion
IIFEs have become less common with the advent of modern JavaScript features like block-scoped variables (let and const) and ES6 modules. However, they still offer a concise way to create isolated scopes and execute code immediately.
- JavaScript Interview Questions (Part2)
- JavaScript Interview Questions (Part3)
- Is JavaScript a true OOP language?
- Advantages and Disadvantages of JavaScript
- Difference Between JavaScript and ECMAScript?
- What is noscript tag?
- Escaping Special Characters in JavaScript
- What is undefined x 1 in JavaScript?
- Logical operators in JavaScript
- Difference between '=', '==' and '===' operators in JS
- How to loop through objects in JavaScript?
- How to write html code dynamically using JavaScript?
- How to add html elements dynamically with JavaScript?
- How to load another html page from javascript?
- What Is The Disadvantages Using InnerHTML In JavaScript?
- What is Browser Object Model
- How to detect the OS on the client machine in JavaScript?
- Difference between window, document, and screen in Javascript?
- Difference between the substr() and substring() in JavaScript?
- How to replace all occurrences of a string in JavaScript?
- Test a string as a literal and as an object in JavaScript
- What is Associative Array in JavaScript
- What is an anonymous function in JavaScript?
- What is the use of 'bind' method in JavaScript?
- Pure functions Vs. Impure functions in javascript
- Is Javascript a Functional Programming Language?
- What's the Difference Between Class and Prototypal Inheritance?
- Javascript, Pass by Value or Pass by Reference?
- How to prevent modification of an object in Javascript?
- What is 'this' keyword in JavaScript?
- How Does Function Hoisting Work in JavaScript?
- What do mean by NULL in Javascript?
- What does the delete operator do in JavaScript?
- What is the Infinity property used for in Javascript?
- Event bubbling and Event Capturing in JavScript?
- What is "strict mode" and how is it used in JavaScript?
- What is the difference between call and apply in JavaScript
- Entire content of a JavaScript source file in a function block?
- What is escape & unescape String functions in JavaScript?
- Instanceof operator in JavaScript
- What Are RESTful (REpresentational State Transfer)Web Services?
- What is Unobtrusive JavaScript & Why it's Important?
- What Does JavaScript Void(0) Mean?
- What are JavaScript Cookies?
- Difference between Client side JavaScript and Server side JavaScript
- TypeError: document.getelementbyid(...) is null
- Uncaught TypeError: Cannot read property of undefined In JavaScript
- Null and Undefined in JavaScript