Dinamiskais ES moduļu imports JavaScript
ES moduļus var importēt dinamiski. Šī iespēja dažkārt var būt noderīga. Apskatīsim, kā tas tiek darīts. Pieņemsim, ka mums ir šāds modulis:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Pieņemsim, ka mēs vēlamies importēt šo moduli ne uzreiz, bet pēc kāda notikuma, piemēram, noklikšķinot uz pogas:
btn.addEventListener('click', function() {
});
Importēsim moduli, izmantojot komandu
import:
btn.addEventListener('click', function() {
import('./test.js');
});
Komanda import savā rezultātā
atgriež promisu:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
Koledža mainīgajā nonāks objekts ar eksportētajām funkcijām:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
Tas, kas tiek eksportēts pēc noklusējuma,
būs atslēgā default:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Importējot var veikt destruktūrizāciju:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Izveidojiet moduli, kas eksportē masīvu
nedēļas dienu nosaukumiem. Nospiežot pogu
importējiet šo moduli un izvadiet
nedēļas dienas saraksta veidā ul.