App strukturieren structure-an-app

NOTE
Adobe empfiehlt die Verwendung des SPA-Editors für Projekte, für die ein Framework-basiertes Client-seitiges Rendering für einzelne Seiten (z. B. React) erforderlich ist. Weitere Informationen

Ein AEM Mobile-Projekt umfasst eine Vielzahl von Inhaltstypen, darunter Seiten, JavaScript- und CSS-Client-Bibliotheken, wiederverwendbare AEM, Inhaltssynchronisierungskonfigurationen und Shell-Inhalt der PhoneGap-App. Die Stützung Ihrer neuen AEM Mobile-App auf das Starter Kit ist eine gute Möglichkeit, alle verschiedenen Inhaltstypen in unsere empfohlene Struktur zu integrieren, um die Portabilität und Wartbarkeit langfristig zu vereinfachen.

Seiteninhalt page-content

Die Seiten Ihrer Anwendung sollten sich alle unter /content/mobileapps befinden, damit sie von der AEM Mobile-Konsole erkannt werden.

chlimage_1-52

Standardmäßig sollte die erste Seite Ihrer App eine Umleitung zu einem seiner untergeordneten Elemente sein, die als Standardsprache der App dienen ("en"sowohl in Geometrixx- als auch in Starter Kit-Fällen). Die Gebietsschema-Seite der obersten Ebene übernimmt normalerweise die Foundation-Komponente "splash-page"(https://experienceleague.adobe.com/libs/mobileapps/components/splash-page?lang=de), die die erforderliche Initialisierung übernimmt, um die Installation von Aktualisierungen der Inhaltssynchronisierung über die Luft zu unterstützen (der ContentInit-Code finden Sie unter /etc/clientlibs/mobile/content-sync/js/contentInit.js).

Vorlagen und Komponenten templates-and-components

Die Vorlage und der Komponentencode für Ihre App sollten sich unter /apps/<Markenname>/<App-Name> befinden. In Übereinstimmung mit der Konvention sollten Sie Ihre Vorlage und den Komponentencode in /apps/<Markenname>/<App-Name> platzieren. Dieses Muster sollte Entwicklern bekannt sein, die bereits mit Site in AEM gearbeitet haben. Dies wird in der Regel so ausgeführt, dass /apps/ standardmäßig in Veröffentlichungsinstanzen auf anonymen Zugriff beschränkt ist. Ihr roher JSP-Code ist also vor potenziellen Angreifern verborgen.

App-spezifische Vorlagen können so konfiguriert werden, dass sie nur angezeigt werden, indem Sie den Eigenschaftsknoten allowedPaths in der Vorlage selbst verwenden und seinen Wert auf "/content/mobileapps(https://experienceleague.adobe.com/"setzen.*?lang=de)?' - oder etwas spezifischeres, wenn die Vorlage nur für eine einzelne App verwendet werden sollte. Die Eigenschaften allowedParents und allowedChildren können auch verwendet werden, um genau zu steuern, welche Vorlagen einem Autor je nachdem, wo die neue Seite erstellt wird, zur Verfügung stehen.

Wenn Sie eine App-Seitenkomponente von Grund auf neu erstellen, wird empfohlen, die sling:resourceSuperType -Eigenschaft auf "mobileapps/components/angular/ng-page"festzulegen. Dadurch wird Ihre Seite sowohl für das Authoring als auch für das Rendering als Einzelseitenanwendung eingerichtet und Sie können alle JSP-Dateien überlagern, die Ihre Komponente möglicherweise ändern muss. Da ng-page überhaupt kein UI-Framework enthält, überlagert ein Entwickler normalerweise (zumindest) "template.jsp"(überlagert von /libs/mobileapps/components/angular/ng-page/template.jsp).

Autorbare Seitenkomponenten, die AngularJS verwenden möchten, verfügen über eine äquivalente sling:resourceSuperType -Komponente unter /libs/mobileapps/components/angular/ng-component , die auf dieselbe Weise überlagert und angepasst werden kann.

JavaScript- und CSS-Clientlibs javascript-and-css-clientlibs

In Client-Bibliotheken stehen Entwicklern einige Optionen zur Verfügung, in denen sie sie im Repository platzieren können. Das folgende Muster wird zur Anleitung angeboten, ist jedoch keine schwierige Anforderung.

Wenn Ihr clientseitiger Code alleine stehen kann und nicht mit einer bestimmten Komponente Ihrer Anwendung in Verbindung steht (d. h., er kann in anderen Anwendungen wiederverwendet werden), empfiehlt Adobe, ihn in /etc/clientlibs/<Markenname>/<lib name> zu speichern. Wenn die clientlib dagegen für eine einzelne App spezifisch ist, können Sie sie als untergeordnetes Element des Design-Knotens Ihrer App verschachteln: /etc/designs/phonegap/<Markenname>/<App-Name>/clientlibs. Verwenden Sie nicht die Kategorie dieser clientlib mit anderen Bibliotheken, sondern betten Sie ggf. andere Bibliotheken ein. Dadurch wird verhindert, dass Entwickler bei jedem Hinzufügen einer Client-Bibliothek zur App neue Konfigurationen für die Inhaltssynchronisierung hinzufügen müssen, anstatt einfach die Eigenschaft "embetts"der Design-Client-Bibliothek der App zu aktualisieren. Betrachten Sie beispielsweise den Konfigurationsknoten "Geometrixx clientlibs-all Content Sync"unter /content/phonegap/geometrixx-outdoors/en/jcr:content/page-app/app-config/clientlibs-all.

Wenn Ihr clientseitiger Code eng mit einer bestimmten Komponente verknüpft ist, platzieren Sie diesen Code in einer Client-Bibliothek, die unter dem Speicherort der Komponente in /apps/ verschachtelt ist, und betten Sie die zugehörige Kategorie in die "Design"-Client-Bibliothek Ihrer App ein.

PhoneGap-Konfiguration phonegap-configuration

Jede AEM Mobile-App enthält einen Ordner, in dem die Konfigurationsdateien gehostet werden, die von der PhoneGap Befehlszeilenschnittstelle und dem PhoneGap-Build unter https://build.phonegap.com/ verwendet werden, um Ihren Webinhalt in eine ausführbare Anwendung umzuwandeln. Im Geometrixx-Beispiel befindet sich dieser Ordner (https://experienceleague.adobe.com/content/phonegap/geometrixx-outdoors/shell/jcr:content/page-app/app-content?lang=de) als Teil der Shell. Eine Designentscheidung wurde getroffen, da er nur Inhalte enthält, die nicht direkt aktualisiert werden können, z. B. Plug-ins, die Geräte-APIs und die Konfiguration der App selbst behandeln.

In diesem Verzeichnis finden Sie auch einige Cordova-Hooks, die zum Installieren von Plug-ins, zum Platzieren von Ressourcendateien an ihren plattformspezifischen Speicherorten und andere Aktionen verwendet werden können, die im Rahmen des Builds ausgeführt werden sollen. Hinweis: Alternativ zum Herunterladen der einzelnen Plug-ins im Rahmen des Builds können Sie dem Muster der Kitchen Sink-App folgen und den Plug-in-Quellcode mit dem Rest Ihres App-Projekts einschließen.

Die nächsten Schritte the-next-steps

Nachdem Sie mehr über die Struktur der App erfahren haben, lesen Sie Erstellen und Bearbeiten von Apps mit der App-Konsole.

recommendation-more-help
2eeeb575-8007-40cc-a72d-206fbc4ddd4b