⊗jsSpMdDI 218 of 294 menu

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.

Português
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Nós usamos cookies para o funcionamento do site, análises e personalização. O processamento de dados é realizado de acordo com a Política de Privacidade.
aceitar todas configurar rejeitar