⊗jsSpMdDI 218 of 294 menu

ES modulok dinamikus importálása JavaScriptben

Az ES modulokat dinamikusan is lehet importálni. Ez a lehetőség néha hasznos lehet. Nézzük meg, hogyan is működik. Tegyük fel, hogy a következő modulunk van:

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

Tegyük fel, hogy ezt a modult nem azonnal, hanem valamilyen esemény hatására szeretnénk importálni, például egy gombra kattintáskor:

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

Importáljuk a modult a import paranccsal:

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

A import parancs eredményeképpen egy Promise-ot ad vissza:

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

A callback változójába egy objektum kerül az exportált függvényekkel:

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

Az, ami alapértelmezetten van exportálva, az a default kulcsban lesz:

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

Használhatunk destructuringot az importáláskor:

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

Készíts egy modult, amely a hét napjainak neveit tartalmazó tömböt exportál. Egy gomb megnyomásakor importáld ezt a modult és jelenítsd meg a hét napjait egy ul listában.

Magyar
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
A weboldal működéséhez, elemzéshez és személyre szabáshoz sütiket használunk. Az adatfeldolgozás a Adatvédelmi irányelvek szerint történik.
összes elfogadása beállítás elutasítás