ES Modullərinin JavaScript-də Dinamik Importu
ES modulları dinamik olaraq import edilə bilər. Bu imkan bəzən faydalı ola bilir. Gəlin bunun necə edildiyinə baxaq. Tutaq ki, bizim aşağıdakı modulumuz var:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Tutaq ki, biz bu modulu dərhal deyil, məsələn, bir düyməyə klikləmə kimi müəyyən bir hadisə əsasında import etmək istəyirik:
btn.addEventListener('click', function() {
});
Gəlin modulu import əmri ilə
import edək:
btn.addEventListener('click', function() {
import('./test.js');
});
import əmri nəticə olaraq
bir promis qaytarır:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
Callback funksiyasının dəyişəninə ixrac olunmuş funksiyalar olan bir obyekt düşəcək:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
Default olaraq ixrac edilənlər
default açarında olacaq:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Import zamanı destrukturizasiya etmək olar:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Həftənin günlərinin adlarını ixrac edən bir modul düzəldin.
Bir düyməyə basıldıqda bu modulu import edin və
günləri ul siyahısı şəklində çıxarın.