Transmission des paramètres de module via les fermetures en JavaScript
Supposons que nous ayons le module suivant :
;(function(root, type, amount) {
let parent = document.querySelector(root);
for (let i = 1; i <= amount; i++) {
let elem = document.createElement(type);
parent.append(elem);
}
})('#parent', 'p', 5);
Comme vous pouvez le voir, trois paramètres sont transmis à ce module : le sélecteur de l'élément parent, le type d'élément à créer et le nombre d'éléments.
Généralement, ces paramètres sont définis sous forme d'objet :
let config = {
root: '#parent',
type: 'p',
amount: 5
}
Passons notre objet en paramètre au module :
;(function(config) {
let parent = document.querySelector(config.root);
for (let i = 1; i <= config.amount; i++) {
let elem = document.createElement(config.type);
parent.append(elem);
}
})(config);
Il est plus courant de réaliser une déstructuration de l'objet de configuration :
;(function({root, type, amount}) {
let parent = document.querySelector(root);
for (let i = 1; i <= amount; i++) {
let elem = document.createElement(type);
parent.append(elem);
}
})(config);