Übergabe von Moduleinstellungen durch Closures in JavaScript
Nehmen wir an, wir haben das folgende Modul:
;(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);
Wie Sie sehen, werden drei Einstellungen an dieses Modul übergeben: der Selektor des übergeordneten Elements, der Typ des zu erstellenden Elements und die Anzahl der Elemente.
In der Regel werden solche Einstellungen als Objekt vorgenommen:
let config = {
root: '#parent',
type: 'p',
amount: 5
}
Lassen Sie uns unser Objekt als Parameter an das Modul übergeben:
;(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);
Es ist üblicher, eine Destrukturierung des Objekts mit den Einstellungen durchzuführen:
;(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);