Dynamisk mappning av modell till komponent för SPA dynamic-model-to-component-mapping-for-spas
I det här dokumentet beskrivs hur den dynamiska mappningen av modell till komponent sker i Javascript SPA SDK för AEM.
ComponentMapping-modul componentmapping-module
The ComponentMapping
-modulen tillhandahålls som ett NPM-paket till frontendprojektet. Det lagrar komponenter för användargränssnitt och tillhandahåller ett sätt för Single Page Application att mappa komponenter för användargränssnitt till AEM resurstyper. Detta aktiverar en dynamisk upplösning för komponenter när JSON-modellen för programmet analyseras.
Varje objekt i modellen innehåller en :type
fält som visar en AEM resurstyp. När den är monterad kan den främre komponenten återge sig själv med det fragment av modellen som den har fått från de underliggande biblioteken.
Se SPA Blueprint -dokument om du vill ha mer information om modellparsning och frontdelens åtkomst till modellen.
Se även npm-paketet: https://www.npmjs.com/package/@adobe/aem-spa-component-mapping
Modellstyrt Single Page-program model-driven-single-page-application
Single Page-program som använder Javascript SPA SDK för AEM är modelldrivna:
-
Front-end-komponenter registrerar sig för Komponentmappningsarkiv.
-
Sedan Behållare, efter att ha fått en modell av Modellprovider, itererar över sitt modellinnehåll (
:items
). -
För en sida, dess underordnade sidor (
:children
) hämta först en komponentklass från Komponentmappning och sedan instansiera den.
Programinitiering app-initialization
Varje komponent utökas med funktionerna i ModelProvider
. Initieringen har därför följande allmänna form:
-
Varje modellprovider initierar sig själv och lyssnar efter ändringar som gjorts i den del av modellen som motsvarar dess inre komponent.
-
The
PageModelManager
måste initieras så som representeras av initieringsflöde. -
När sidmodellhanteraren har lagrats returnerar den hela appmodellen.
-
Den här modellen skickas sedan till frontendroten Behållare -komponenten i programmet.
-
Delar av modellen sprids slutligen till varje enskild underordnad komponent.