Динамички увоз ES модула у JavaScript-у
ES модули се могу увозити динамички. Ова могућност понекад може бити корисна. Да видимо како се то ради. Претпоставимо да имамо следећи модул:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Претпоставимо да желимо да увеземо овај модул не одмах, већ на основу одређеног догађаја, на пример, клика на дугме:
btn.addEventListener('click', function() {
});
Увезимо модул користећи команду
import:
btn.addEventListener('click', function() {
import('./test.js');
});
Команда import као резултат
враћа промис:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
У променљиву колбек функције биће смештен објекат са извезеним функцијама:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
Оно што је извезено подразумевано,
биће смештено у кључу default:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Може се извршити деструктурирање приликом увоза:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Направите модул који извози низ
назива дана у недељи. При клику на дугме
увезите овај модул и прикажите
дане у недељи као листу ul.