avatar

IIFE vs Closure

An IIFE (Immediately Invoked Function Expression) is a JavaScript function that runs as soon as it is defined. It is often used to create a new scope for variables and avoid polluting the global scope.

;(function () {
  const message = 'Hello from an IIFE!'

  console.log(message)
})()

A closure is the combination of a function bundled together with references to its surrounding state (the lexical environment). It gives you access to an outer function's scope from an inner function.

function outerFunction() {
  const outerVariable = "I'm from the outer function"

  function innerFunction() {
    console.log(outerVariable)
  }

  return innerFunction
}

const closureExample = outerFunction()

closureExample() // I'm from the outer function

A example use IIFE and Closure to make a counter.

<script>
  const updateClickCount = (function () {
    const counter = 0

    return function () {
      ++counter
      document.getElementById('spnCount').innerHTML = counter
    }
  })()
</script>

<html>
  <button onclick="updateClickCount()">click me</button>
  <div>you've clicked <span id="spnCount"> 0 </span> times!</div>
</html>