Динамический импорт ES модулей по событию
ES
модули можно импортировать динамически. Эта возможность иногда бывает полезной. Давайте посмотрим, как это делается. Пусть у нас есть следующий модуль:
/src/test.jsexport function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Пусть мы хотим импортировать этот модуль не сразу, а по некоторому событию, например, по клику на кнопку:
/src/index.jsbtn.addEventListener('click', function() {
});
Импортируем модуль с помощью команды
import
:
/src/index.jsbtn.addEventListener('click', function() {
import('./test.js');
});
Команда import
своим результатом возвращает промис:
/src/index.jsbtn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
В переменную коллбэка попадет объект с экспортированными функциями:
/src/index.jsbtn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
То, что экспортируется по умолчанию, будет лежать в ключе default
:
/src/index.jsbtn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Можно выполнять деструктуризацию при импорте:
/src/index.jsbtn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Динамический множественный импорт
Можно динамически импортировать сразу несколько модулей:
/src/index.jsbtn.addEventListener('click', function() {
Promise.all([
import('./module1.js'),
import('./module2.js'),
import('./module3.js'),
])
.then(([module1, module2, module3]) => {
});
});