Importação Dinâmica de Módulos ES em JavaScript
Os módulos ES podem ser importados dinamicamente. Essa funcionalidade às vezes é útil. Vamos ver como isso é feito. Suponha que temos o seguinte módulo:
export function func1() {
return '1'
}
export function func2() {
return '2'
}
export default function() {
return 'text';
};
Suponha que queremos importar este módulo não imediatamente, mas mediante algum evento, por exemplo, ao clicar em um botão:
btn.addEventListener('click', function() {
});
Vamos importar o módulo usando o comando
import:
btn.addEventListener('click', function() {
import('./test.js');
});
O comando import retorna
uma promessa como resultado:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
});
});
No callback, a variável receberá um objeto com as funções exportadas:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let res1 = mod.func1();
let res2 = mod.func2();
console.log(res1, res2);
});
});
O que é exportado como padrão
estará na chave default:
btn.addEventListener('click', function() {
import('./test.js').then(mod => {
let dfn = mod.default;
console.log(dfn);
});
});
Podemos realizar a desestruturação durante a importação:
btn.addEventListener('click', function() {
import('./test.js').then(({func1, func2}) => {
let res1 = func1();
let res2 = func2();
console.log(res1, res2);
});
});
Crie um módulo que exporte um array
com os nomes dos dias da semana. Ao clicar em um botão
importe este módulo e exiba
os dias da semana em uma lista ul.