Dynamisk import av ES-moduler i JavaScript
ES-moduler kan importeres dynamisk. Denne muligheten er noen ganger nyttig. La oss se hvordan det gjøres. La oss si at vi har følgende modul:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
La oss si at vi vil importere denne modulen ikke umiddelbart, men ved en hendelse, for eksempel ved klikk på en knapp:
btn.addEventListener('click', function() {
});
La oss importere modulen med kommandoen
import:
btn.addEventListener('click', function() {
import('./test.js');
});
Kommandoen import returnerer
et promise som resultat:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
I callback-variabelen vil vi få et objekt med de eksporterte funksjonene:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
Det som eksporteres som standard,
vil ligge i nøkkelen default:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Du kan utføre destructuring ved import:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Lag en modul som eksporterer en array
med ukedagers navn. Ved klikk på en knapp,
importer denne modulen og vis
ukedagene som en ul-liste.