AEM as aCloud Service支援部署ui.apps
元件指令碼,作為預編譯的捆綁指令碼。 這可讓開發人員在建置時預先編譯其指令碼,並以OSGi套件組合的形式封裝。
將指令碼部署為預編譯的捆綁指令碼具有以下優點:
Import-Package
和Export-Package
套件組合標題明確定義Java API指令碼相依性sling:resourceSuperType
)和委派給其他資源類型(例如透過HTL的data-sly-resource
區塊元素或透過sling:include
JSP標籤)可透過套件的中繼資料來對應htl-maven-plugin
可驗證HTL指令碼的語法,但也可用來將HTL指令碼傳輸至Java類別。 然後,這些資料夾會新增至您Maven專案的generated-sources
資料夾,並由maven-compiler-plugin
擷取。
可新增bnd-maven-plugin
以產生OSGi套件組合的Java API匯入中繼資料。
OSGi框架提供了一種強大的定義要求和功能以表示不同元件之間的合同的方法。 這些會透過中繼資料加以說明,並在執行階段強制執行。 套件指令碼使用此機制來表示其繼承關係(sling:resourceSuperType
)以及委派(包括呈現過程中的其他資源類型)。
scriptingbundle-maven-plugin專案的bnd
外掛程式可用來擷取與ui.apps
內容套件所提供指令碼相對應的需求和功能。
從第31版開始,AEM專案原型可用來正確將AEM設為Cloud Service專案,以使用預先編譯的套裝指令碼。 此外,AEM專案原型會將AEM設定為Cloud ServiceSDK建置分析器Maven Plugin,以驗證Java套件層級和指令碼層級的相依性。