Le applicazioni a pagina singola (SPA) possono offrire esperienze coinvolgenti agli utenti di siti web. Gli sviluppatori desiderano essere in grado di creare siti utilizzando framework SPA e gli autori desiderano modificare i contenuti all’interno di AEM per un sito creato utilizzando tali frameworks.
Questo articolo presenta questioni importanti da considerare quando si impegna uno sviluppatore front-end a sviluppare un SPA per l’AEM e fornisce una panoramica dell’architettura dell’AEM in relazione alla diffusione dell’SPA sull’AEM.
L’editor SPA è la soluzione consigliata per i progetti che richiedono un rendering lato client basato sul framework SPA (ad esempio, React o Angular).
Lo sviluppo di applicazioni a pagina singola in AEM presuppone che lo sviluppatore front-end osservi le best practice standard durante la creazione di una SPA. Se, in qualità di sviluppatore front-end, segui queste best practice generali e alcuni principi specifici dell’AEM, il tuo SPA funzionerà con AEM e le sue funzionalità di authoring dei contenuti.
Se tieni presenti questi principi durante lo sviluppo dell’SPA, sarà il più possibile flessibile e a prova di futuro, consentendo al contempo tutte le funzionalità di authoring dell’AEM supportate.
Se non è necessario supportare le funzioni di creazione dell’AEM, potrebbe essere necessario considerare un Modello di progettazione SPA.
Come per qualsiasi altro componente, i componenti devono essere progettati in modo da massimizzarne la portabilità. È necessario evitare qualsiasi modello che possa compromettere la portabilità o la riutilizzabilità dei componenti per garantire compatibilità, flessibilità e manutenibilità in futuro.
Il SPA risultante dovrebbe essere costruito con componenti altamente portatili e riutilizzabili.
Lo sviluppatore front-end deve considerarsi responsabile della creazione di una libreria di componenti SPA utilizzati per creare l’app. Lo sviluppatore front-end ha il pieno controllo della struttura interna dei componenti. Tuttavia AEM in ogni momento possiede la struttura del sito.
Questo significa che lo sviluppatore front-end può aggiungere contenuto del cliente prima o dopo il punto di ingresso dei componenti e può anche effettuare chiamate di terze parti all’interno del componente. Tuttavia, lo sviluppatore front-end non ha il pieno controllo, ad esempio, del modo in cui i componenti vengono nidificati.
L’SPA deve basarsi solo sul rendering dinamico dei contenuti. Questa è l’aspettativa predefinita in cui l’AEM recupera ed esegue il rendering di tutti gli elementi secondari della struttura del contenuto.
Qualsiasi rendering esplicito che punti a contenuti specifici viene considerato come rendering statico e, sebbene supportato, non è compatibile con le funzioni di authoring dei contenuti AEM. Questo va anche contro il principio di portabilità.
Come per il rendering, anche tutte le operazioni di instradamento devono essere dinamiche. Nell'AEM, l'SPA deve essere sempre proprietario dell'instradamento e l’AEM lo ascolta e ne recupera i contenuti in base a esso.
Qualsiasi instradamento statico funziona rispetto al principio di portabilità e limita l’autore in quanto non è compatibile con le funzioni di authoring dei contenuti dell’AEM. Ad esempio, con il routing statico, se l’autore di contenuto desidera modificare un percorso o una pagina, deve chiedere allo sviluppatore front-end di farlo.
Qualsiasi progetto AEM deve utilizzare l’archetipo di progetto AEM, che supporta progetti SPA utilizzando React o Angular e sfrutta l’SDK di SPA.
Se il Principi per lo sviluppo dell'SPA nell'AEM sono seguiti, quindi l’SPA funzionerà con tutte le funzioni di authoring dei contenuti dell’AEM supportate.
In alcuni casi, tuttavia, ciò non è del tutto necessario. Nella tabella seguente viene fornita una panoramica dei vari modelli di progettazione, dei vantaggi e degli svantaggi.
Modello di progettazione |
Vantaggi | Svantaggi |
---|---|---|
L’AEM viene utilizzato come CMS headless senza utilizzare Framework SDK dell’editor SPA. | Lo sviluppatore front-end ha il pieno controllo dell’app. | Gli autori di contenuti non possono sfruttare l’esperienza di authoring dei contenuti AEM. Il codice non è né portatile né riutilizzabile se contiene riferimenti statici o instradamento. Non consente l’utilizzo dell’editor di modelli, pertanto lo sviluppatore front-end deve mantenere i modelli modificabili tramite JCR. |
Lo sviluppatore front-end utilizza il framework SDK dell’editor SPA, ma apre solo alcune aree all’autore di contenuto. | Lo sviluppatore mantiene il controllo sull’app abilitando l’authoring solo nelle aree limitate dell’app. | Gli autori dei contenuti sono limitati a un set limitato di esperienze di authoring dei contenuti AEM. Il codice rischia di non essere né portatile né riutilizzabile se contiene riferimenti statici o instradamento. Non consente l’utilizzo dell’editor di modelli, pertanto lo sviluppatore front-end deve mantenere i modelli modificabili tramite JCR. |
Il progetto sfrutta appieno l’SDK dell’editor dell’SPA e i componenti front-end vengono sviluppati come una libreria e la struttura del contenuto dell’app viene delegata all’AEM. | L’app è riutilizzabile e portatile. L’autore del contenuto può modificare l’app utilizzando l’esperienza di authoring dei contenuti AEM. L’SPA è compatibile con l’editor di modelli. |
Lo sviluppatore non ha il controllo della struttura dell’app e della parte di contenuto delegata all’AEM. Lo sviluppatore può comunque riservare alcune aree dell’app per i contenuti che non devono essere creati con l’AEM. |
Anche se tutti i modelli sono supportati nell'AEM, solo implementando il terzo (e quindi seguendo il Principi di sviluppo dell'SPA nell'AEM) gli autori dei contenuti potranno interagire con il contenuto dell’SPA nell’AEM e modificarlo come sono abituati.
Generalmente, se l’SPA segue le Principi di sviluppo dell'SPA per l'AEM, il suo SPA funzionerà nell’AEM e sarà modificabile utilizzando l’Editor AEM SPA.
Segui questi passaggi per preparare il tuo SPA esistente a lavorare con l’AEM.
Rendi i componenti JS modulari.
Rendi possibile il rendering in qualsiasi ordine, posizione e dimensione.
Utilizza i contenitori forniti dal nostro SDK per posizionare i componenti sullo schermo.
L’AEM fornisce un componente per il sistema di pagine e paragrafi da utilizzare.
Crea un componente AEM per ogni componente JS.
I componenti AEM definiscono la finestra di dialogo e l’output JSON.
Il compito principale nello spingere uno sviluppatore front-end a creare un SPA per l’AEM è quello di concordare i componenti e i relativi modelli JSON.
Di seguito è riportato uno schema dei passaggi che uno sviluppatore front-end deve seguire quando sviluppa un SPA per l’AEM.
Concordare i componenti e il relativo modello JSON
Gli sviluppatori front-end e gli sviluppatori back-end dell’AEM devono concordare i componenti necessari e un modello, in modo da garantire una corrispondenza uno a uno tra i componenti SPA e i componenti back-end.
I componenti AEM sono ancora necessari soprattutto per fornire finestre di dialogo di modifica ed esportare il modello di componente.
Nei componenti React, accedi al modello tramitethis.props.cqModel
Una volta concordati i componenti e impostato il modello JSON, lo sviluppatore front-end è libero di sviluppare l’SPA e può semplicemente accedere al modello JSON tramite this.props.cqModel
.
Implementare i render()
metodo
Lo sviluppatore front-end implementa render()
il metodo che ritiene più appropriato e può utilizzare i campi del cqModel
proprietà. In questo modo vengono generati i frammenti DOM e HTML che verranno inseriti nella pagina. Questo è il modo standard per creare un’app in React.
Mappare il componente al tipo di risorsa AEM tramiteMapTo()
Il mapping memorizza le classi dei componenti e viene utilizzato internamente dal Container
per recuperare e creare un’istanza dinamica dei componenti in base al tipo di risorsa specificato.
Questo funge da "colla" tra front-end e back-end in modo che l’editor sappia a quali componenti corrispondono i componenti react.
Il Page
e ResponsiveGrid
sono buoni esempi di classi che estendono la base Container
.
Definisci i EditConfig
come parametro perMapTo()
Questo parametro è necessario per indicare all’editor come deve essere denominato il componente, purché non sia ancora stato eseguito il rendering o non sia presente alcun contenuto da riprodurre.
Estendi il fornito Container
classe per pagine e contenitori
I sistemi di pagine e paragrafi devono estendere questa classe in modo che la delega ai componenti interni funzioni come previsto.
Implementare una soluzione di routing che utilizzi HTML5 History
API.
Quando ModelRouter
è abilitato, chiamando il pushState
e replaceState
attiverà una richiesta al PageModelManager
per recuperare un frammento mancante del modello.
La versione corrente del ModelRouter
supporta solo l’utilizzo di URL che puntano al percorso effettivo delle risorse dei punti di ingresso del modello Sling. Non supporta l’utilizzo di URL personalizzati o alias.
Il ModelRouter
può essere disabilitato o configurato per ignorare un elenco di espressioni regolari.
Questi blocchi di codice illustrano in che modo i componenti React e Angular non richiedono nulla che sia specifico per Adobe o AEM.
Il MapTo
helper è la "colla" che consente di abbinare i componenti back-end e front-end:
Per ulteriori informazioni sull'utilizzo di MapTo
e la creazione dell’SPA per l’AEM in generale, consulta la Guida introduttiva per il framework scelto.
L’architettura generale dell’AEM, compresi gli ambienti di sviluppo, authoring e pubblicazione, non cambia quando si utilizza l’SPA. Tuttavia, è utile capire in che modo lo sviluppo dell’SPA si inserisce in questa architettura.
Ambiente di build
Qui è dove vengono estratti l'origine dell'applicazione SPA e l'origine dei componenti.
Autore AEM
I contenuti vengono creati nell’autore dell’AEM, inclusa la creazione dell’SPA.
Quando si modifica un SPA utilizzando l’Editor SPA nell’ambiente di authoring:
cq-data
attributi.cq-data
attributi consente all’editor di caricare informazioni di pagina aggiuntive in modo da sapere quali configurazioni di modifica sono disponibili per i componenti.AEM Publish
Qui vengono pubblicati per il consumo pubblico i contenuti creati e le librerie compilate, inclusi gli artefatti delle applicazioni SPA, clientlibs e componenti.
Dispatcher/CDN
Il dispatcher funge da livello di caching dell’AEM per i visitatori del sito.
All'interno dell'AEM non è necessario eseguire meccanismi di sviluppo JavaScript né eseguire Javascript stesso. L’AEM ospita solo gli artefatti compilati dell’applicazione SPA.
Per una panoramica della struttura e del funzionamento di un semplice SPA nell’AEM, consulta la guida introduttiva per entrambi React e Angular.
Per una guida dettagliata alla creazione di un proprio SPA, vedi Guida introduttiva all’Editor SPA dell’AEM - Esercitazione eventi WKND.
Per ulteriori dettagli sul modello dinamico di mappatura dei componenti e sul suo funzionamento all’interno dell’SPA nell’AEM, vedi l’articolo Mappatura di un modello dinamico a un componente per SPA.
Se desideri implementare l’SPA nell’AEM per un framework diverso da React o Angular o semplicemente approfondire il funzionamento dell’SDK SPA per l’AEM, consulta Blueprint SPA articolo.