ES Modüllerinin JavaScript'te Dinamik İthalatı
ES modülleri dinamik olarak ithal edilebilir. Bu özellik bazen kullanışlı olabilir. Bakalım nasıl yapılıyor. Şu modüle sahip olduğumuzu varsayalım:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Bu modülü hemen değil de, bir olay üzerine, örneğin bir butona tıklandığında ithal etmek istediğimizi varsayalım:
btn.addEventListener('click', function() {
});
Modülü import komutuyla
ithal edelim:
btn.addEventListener('click', function() {
import('./test.js');
});
import komutu, sonucu olarak
bir promise döndürür:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
Callback fonksiyonunun değişkenine, ihraç edilmiş fonksiyonlarla birlikte bir nesne gelecek:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
Varsayılan olarak ihraç edilen şey,
default anahtarında bulunacak:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
İthalat sırasında destructuring yapılabilir:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Haftanın günlerinin isimlerini dizi olarak
ihraç eden bir modül yapın. Bir butona basıldığında
bu modülü ithal edin ve günleri bir ul
listesi olarak yazdırın.