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

Plus Minus HackerRank Solution in Java | Programming Blog

Java Solution for HackerRank Plus Minus Problem Given an array of integers, calculate the ratios of its elements that are positive , negative , and zero . Print the decimal value of each fraction on a new line with 6 places after the decimal. Example 1 : array = [1, 1, 0, -1, -1] There are N = 5 elements, two positive, two negative and one zero. Their ratios are 2/5 = 0.400000, 2/5 = 0.400000 and 1/5 = 0.200000. Results are printed as:  0.400000 0.400000 0.200000 proportion of positive values proportion of negative values proportion of zeros Example 2 : array = [-4, 3, -9, 0, 4, 1]  There are 3 positive numbers, 2 negative numbers, and 1 zero in array. Following is answer : 3/6 = 0.500000 2/6 = 0.333333 1/6 = 0.166667 Lets see solution Solution 1 import java.io.*; import java.math.*; import java.security.*; import java.text.*; import java.util.*; import java.util.concurrent.*; import java.util.function.*; import java.util.regex.*; import java.util.stream.*; import static jav...

Flipping the Matrix HackerRank Solution in Java with Explanation

Java Solution for Flipping the Matrix | Find Highest Sum of Upper-Left Quadrant of Matrix Problem Description : Sean invented a game involving a 2n * 2n matrix where each cell of the matrix contains an integer. He can reverse any of its rows or columns any number of times. The goal of the game is to maximize the sum of the elements in the n *n submatrix located in the upper-left quadrant of the matrix. Given the initial configurations for q matrices, help Sean reverse the rows and columns of each matrix in the best possible way so that the sum of the elements in the matrix's upper-left quadrant is maximal.  Input : matrix = [[1, 2], [3, 4]] Output : 4 Input : matrix = [[112, 42, 83, 119], [56, 125, 56, 49], [15, 78, 101, 43], [62, 98, 114, 108]] Output : 119 + 114 + 56 + 125 = 414 Full Problem Description : Flipping the Matrix Problem Description   Here we can find solution using following pattern, So simply we have to find Max of same number of box like (1,1,1,1). And ...