Dinamični uvoz ES modulov v JavaScript
ES module je mogoče uvoziti dinamično. Ta zmožnost je včasih uporabna. Poglejmo, kako se to naredi. Recimo, da imamo naslednji modul:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Recimo, da želimo uvoziti ta modul ne takoj, ampak ob določenem dogodku, na primer ob kliku na gumb:
btn.addEventListener('click', function() {
});
Uvozimo modul z ukazom
import:
btn.addEventListener('click', function() {
import('./test.js');
});
Ukaz import kot rezultat
vrne promis:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
V spremenljivko povratnega klica bo prišel objekt z izvozanimi funkcijami:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
Kar je izvozano privzeto,
bo v ključu default:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Lahko izvedemo destrukturiranje pri uvozu:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Naredite modul, ki izvozi seznam
imen dni v tednu. Ob pritisku na gumb
uvozite ta modul in prikažite
dneve v tednu kot seznam ul.