Closure scope
Cuando una función está dentro de otra función, puede acceder tanto a su propio closure scope como al closure scope padre de la función externa.
Las reglas de closure scope aplican también a las funciones fat arrow (=>).
La principal ventaja al usar closure scope para componer objetos es que elimina la complejidad de los prototipos, contexto (this) y la necesidad de invocar la función con new.
Es recomendable utilizar la composición de funciones en lugar de la herencia de prototipos y optimizar si es necesario.
Ejemplos:
function outerFunction() {
let isEnabled = true;
function getStatus() {
console.log(isEnabled);
}
getStatus(); // imprime true
isEnabled = false;
getStatus(); // imprime false
}
outerFunction();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' }El siguiente ejemplo es funcionalmente equivalente y al mismo nivel de composición que los ejemplos de herencia de prototipos:
El ejemplo anterior no tiene una cadena de prototipos.
Otro ejemplo implementando la función prefixer:
Last updated
Was this helpful?