Dinaminis ES modulių importas JavaScript
ES modulius galima importuoti dinamiškai. Ši galimybė kartais būna naudinga. Pažiūrėkime, kaip tai daroma. Tarkime, kad turime šį modulį:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Tarkime, kad norime importuoti šį modulį ne iš karto, o pagal tam tikrą įvykį, pavyzdžiui, paspaudus mygtuką:
btn.addEventListener('click', function() {
});
Importuokime modulį naudodami komandą
import:
btn.addEventListener('click', function() {
import('./test.js');
});
Komanda import savo rezultatu
grąžina promisą:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
Į atgalinio kvietimo kintamąjį pateks objektas su eksportuotomis funkcijomis:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
Tai, kas eksportuojama pagal nutylėjimą,
bus rakte default:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Galima atlikti destruktyrizavimą importuojant:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Sukurkite modulį, eksportuojantį masyvą
savaitės dienų pavadinimų. Paspaudus mygtuką
importuokite šį modulį ir išveskite
savaitės dienas sąrašo ul pavidalu.