Skip to main content

IIFE in JavaScript


An IIFE means Immediately Invoked Function Expression. IIFE is a JavaSctript function that runs as soon as it is defined.

What is IIFE in JavaScript? | JavaScript IIFE with example

 
An IIFE means Immediately Invoked Function Expression. IIFE is a JavaSctript function that runs as soon as it is defined.
I know it is difficult to understand but i describe in simplicity so lets start.
So this is normal function in JavaScript that we used in our daily life.

// Normal function in JavaScript

function addTwoValues() {

var a = 10;
var b = 10;
  var answer = x + y; 
 
  console.log(answer);
}

addTogether();

So here is function addTwoValues() which is add two values and print the output.
I called that function after in last where function ends.
So, there might be question in your mind yes we use like this what is problem in that.

In above example our variables are immutable which means we can not change from outside of function. So our variables are not accessed, but what about function that can be accessed from anywhere.

So we have solution for that it calls IIFE.
It is a design pattern which is also known as a Self-Executing Anonymous Function and contains two major parts:
  1. The first is the anonymous function with lexical scope enclosed within the Grouping Operator (). This prevents accessing variables within the IIFE idiom as well as polluting the global scope.
  2. The second part creates the immediately invoked function expression () through which the JavaScript engine will directly interpret the function.
So the first thing we do is wrap our addTwoValues function in breakets.
// Function Expression in JavaScript

(function addTwoValues() {

var a = 10;
var b = 10;
   var answer = x + y; 
  
  console.log(answer);
 });

 addTogether();

Then delete function name. So now how we can call this function in your head.
Well its simple we add brackets at the end of the function (before the semicolon).

// Immediately Invoked Function Expression in JavaScript

(function () {

var a = 10;
var b = 10;
  var answer = x + y;
 
  console.log(answer);

})();

The function becomes a function expression which is immediately executed. The variable within the expression can not be accessed from outside it.

lets see another example of IIFE.
so you understand very easily from example.

(function() {

    // Declared variable name and assign value
    var name = "UniqueThrowdown";

})();

console.log(name);
// Throws "Uncaught ReferenceError: name is not defined"

At above example if we try to access name variable then we got error.
So how we can access that variable? Lets see.

var result = (function() {

    // Declared variable name and assign value
    var name = "UniqueThrowdown";
    return name;

})();

console.log(result);
// UniqueThrowdown

I am adding MDN website link where you can learn more about IIFE.

    Learn More About IIFE



Comments

  1. This is really awesome feature when it comes for security..
    And really nice blog..
    I fully understand what is iife
    thanks..

    ReplyDelete

Post a Comment

Popular posts from this blog

Queen's Attack II HackerRank Solution in Java with Explanation

Queen's Attack II Problem's Solution in Java (Chessboard Problem)   Problem Description : You will be given a square chess board with one queen and a number of obstacles placed on it. Determine how many squares the queen can attack.  A queen is standing on an n * n chessboard. The chess board's rows are numbered from 1 to n, going from bottom to top. Its columns are numbered from 1 to n, going from left to right. Each square is referenced by a tuple, (r, c), describing the row r and column c, where the square is located. The queen is standing at position (r_q, c_q). In a single move, queen can attack any square in any of the eight directions The queen can move: Horizontally (left, right) Vertically (up, down) Diagonally (four directions: up-left, up-right, down-left, down-right) The queen can move any number of squares in any of these directions, but it cannot move through obstacles. Input Format : n : The size of the chessboard ( n x n ). k : The number of obstacles...

Sales by Match HackerRank Solution | Java Solution

HackerRank Sales by Match problem solution in Java   Problem Description : Alex works at a clothing store. There is a large pile of socks that must be paired by color for sale. Given an array of integers representing the color of each sock, determine how many pairs of socks with matching colors there are. For example, there are n=7 socks with colors socks = [1,2,1,2,1,3,2]. There is one pair of color 1 and one of color 2 . There are three odd socks left, one of each color. The number of pairs is 2 .   Example 1 : Input : n = 6 arr = [1, 2, 3, 4, 5, 6] Output : 0 Explanation : We have 6 socks with all different colors, So print 0. Example 2 : Input : n = 10 arr = [1, 2, 3, 4, 1, 4, 2, 7, 9, 9] Output : 4 Explanation : We have 10 socks. There is pair of color 1, 2, 4 and 9, So print 4. This problem easily solved by HashMap . Store all pair of socks one by one in Map and check if any pair is present in Map or not. If pair is present then increment ans variable by 1 ...