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 ցուցակի տեսքով: