ES modulok dinamikus importálása JavaScriptben
Az ES modulokat dinamikusan is lehet importálni. Ez a lehetőség néha hasznos lehet. Nézzük meg, hogyan is működik. Tegyük fel, hogy a következő modulunk van:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Tegyük fel, hogy ezt a modult nem azonnal, hanem valamilyen esemény hatására szeretnénk importálni, például egy gombra kattintáskor:
btn.addEventListener('click', function() {
});
Importáljuk a modult a
import paranccsal:
btn.addEventListener('click', function() {
import('./test.js');
});
A import parancs eredményeképpen
egy Promise-ot ad vissza:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
A callback változójába egy objektum kerül az exportált függvényekkel:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
Az, ami alapértelmezetten van exportálva,
az a default kulcsban lesz:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Használhatunk destructuringot az importáláskor:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Készíts egy modult, amely a hét napjainak neveit tartalmazó tömböt exportál.
Egy gomb megnyomásakor importáld ezt a modult és jelenítsd meg
a hét napjait egy ul listában.