⊗jsSpMdDI 218 of 294 menu

Dynamisk import av ES-moduler i JavaScript

ES-moduler kan importeres dynamisk. Denne muligheten er noen ganger nyttig. La oss se hvordan det gjøres. La oss si at vi har følgende modul:

export function func1() { return '1' } export function func2() { return '2' } export default function() { return 'text'; };

La oss si at vi vil importere denne modulen ikke umiddelbart, men ved en hendelse, for eksempel ved klikk på en knapp:

btn.addEventListener('click', function() { });

La oss importere modulen med kommandoen import:

btn.addEventListener('click', function() { import('./test.js'); });

Kommandoen import returnerer et promise som resultat:

btn.addEventListener('click', function() { import('./test.js').then(mod => { }); });

I callback-variabelen vil vi få et objekt med de eksporterte funksjonene:

btn.addEventListener('click', function() { import('./test.js').then(mod => { let res1 = mod.func1(); let res2 = mod.func2(); console.log(res1, res2); }); });

Det som eksporteres som standard, vil ligge i nøkkelen default:

btn.addEventListener('click', function() { import('./test.js').then(mod => { let dfn = mod.default; console.log(dfn); }); });

Du kan utføre destructuring ved import:

btn.addEventListener('click', function() { import('./test.js').then(({func1, func2}) => { let res1 = func1(); let res2 = func2(); console.log(res1, res2); }); });

Lag en modul som eksporterer en array med ukedagers navn. Ved klikk på en knapp, importer denne modulen og vis ukedagene som en ul-liste.

Norsk
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Vi bruker informasjonskapsler for nettstedets funksjonalitet, analyse og personalisering. Behandling av data foregår i henhold til Personvernerklæringen.
godta alle tilpass avvis