Полный цикл в digital

Динамический импорт 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]) => {
  });
});
Заполните форму уже сегодня!
Для начала сотрудничества необходимо заполнить заявку или заказать обратный звонок. В ответ получите коммерческое предложение, которое будет содержать индивидуальную стратегию с учетом требований и поставленных задач
Работаем по будням с 9:00 до 18:00. Заявки, отправленные в выходные, обрабатываем в первый рабочий день до 12:00.
Спасибо, ваш запрос принят и будет обработан!
Эйч Маркетинг