ES-moduulien dynaaminen tuonti JavaScriptissä
ES-moduuleja voidaan tuoda dynaamisesti. Tämä ominaisuus on joskus hyödyllinen. Katsotaan kuinka se tehdään. Oletetaan, että meillä on seuraava moduuli:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Oletetaan, että haluamme tuoda tämän moduulin ei heti, vaan jonkin tapahtuman perusteella, esimerkiksi painikkeen klikkauksen yhteydessä:
btn.addEventListener('click', function() {
});
Tuodaan moduuli käyttämällä komentoa
import:
btn.addEventListener('click', function() {
import('./test.js');
});
import-komento palauttaa
promisen tuloksenaan:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
Kallbackin muuttujaan tulee objekti viedyillä funktioilla:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
Se, mikä viedään oletusarvoisesti,
tulee olemaan avaimessa default:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Tuonnin yhteydessä voidaan suorittaa destrukturointi:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Tee moduuli, joka vie taulukon
viikonpäivien nimistä. Painikkeen painalluksesta
tuo tämä moduuli ja näytä
viikonpäivät listana ul.