Pengimportan Dinamik Modul ES dalam JavaScript
Modul ES boleh diimport secara dinamik. Kebolehan ini kadang-kadang berguna. Mari kita lihat bagaimana ia dilakukan. Katakan kita mempunyai modul berikut:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Katakan kita mahu mengimport modul ini bukan serta-merta, tetapi berdasarkan beberapa peristiwa, contohnya, apabila klik pada butang:
btn.addEventListener('click', function() {
});
Mari import modul menggunakan perintah
import:
btn.addEventListener('click', function() {
import('./test.js');
});
Perintah import memberikan hasilnya
yang mengembalikan janji (promise):
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
Ke dalam pembolehubah panggil balik akan masuk objek dengan fungsi yang dieksport:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
Apa yang dieksport secara lalai,
akan berada dalam kunci default:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Boleh lakukan destructuring semasa mengimport:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Buat sebuah modul, yang mengeksport array
nama hari dalam minggu. Apabila butang ditekan
import modul ini dan paparkan
hari dalam minggu dalam bentuk senarai ul.