Closure scope

Ejemplos:

function outerFunction() {
  let isEnabled = true;
  function getStatus() {
    console.log(isEnabled);
  }
  getStatus(); // imprime true
  isEnabled = false;
  getStatus(); // imprime false
}
outerFunction();
  • Si existiese una colisión con algún nombre de variable con la de un argumento de una función tomará la más cercana por prioridad de scope.

  • Closure scope no puede ser accesible fuera de una función (Provee una encapsulación de un estado privado).

function animal(type) {
  let id = 0;
  return (name) => {
    id += 1;
    return {
      id,
      type,
      name
    };
  };
}
const createDog = animal('dog');
const createCat = animal('cat');
const scott = createDog('Scott');
const firulais = createDog('Firulais');
const fifi = createCat('Fifi');
console.log(scott); // { id: 1, type: 'dog', name: 'Scott' }
console.log(firulais); // { id: 2, type: 'dog', name: 'Firulais' }
console.log(fifi); // { id: 1, type: 'cat', name: 'Fifi' }
  • La función animal tiene una variable id dentro de su scope, y toma el argumento type, y retorna una función con el id, tipo y nombre, ya que tiene acceso al closure scope de la función padre.

  • La función animal se invoca dos veces y es asignado a createDog y createCat. Estas funciones tienen diferentes instancias de closure scope. Los objetos scott y firulais son instanciados por createDog.

El siguiente ejemplo es funcionalmente equivalente y al mismo nivel de composición que los ejemplos de herencia de prototipos:

function employee() {
  const salary = () => {
    console.log(`Su salario es de $.12,000.00`);
  };
  return { salary };
}

function salesperson(name) {
  const sell = () => {
    console.log(`Es vendido por ${name}`);
  };
  return {
    ...employee(), // Spread operator (copy properties).
    sell
  };
}
const smith = salesperson('Smith Peterson');
smith.sell(); // Es vendido Smith Peterson
smith.salary(); // Su salario es de $.12,000.00
console.log(Object.getPrototypeOf(smith)); // {}
console.log(Object.getPrototypeOf(salesperson)); // [Function]

Otro ejemplo implementando la función prefixer:

'use strict';

function prefixer(type) {
  return (name) => {
    return `${type}${name}`;
  };
}

const sayHiTo = prefixer('Hello ');
const sayByeTo = prefixer('Goodbye ');
console.log(sayHiTo('Dave')); // Hello Dave
console.log(sayHiTo('Annie')); // Hello Annie
console.log(sayByeTo('Dave')); // Goodbye Dave

Last updated

Was this helpful?