社交元件架構(SCF)簡化了在伺服器端和用戶端配置、自訂和擴充Communities元件的程式。
該框架的好處:
使用互動式社群元件指南探索製作或發佈執行個體。
在SCF中,元件由SocialComponent POJO、Handlebars JS範本(用於呈現元件)和CSS(用於設定元件樣式)組成。
Handlebars JS範本可擴充模型/檢視JS元件,以處理使用者與用戶端上元件的互動。
如果元件需要支援資料修改,則可寫入SocialComponent API實作,以支援編輯/儲存與傳統Web應用程式中模型/資料物件類似的資料。 此外,可以添加操作(控制器)和操作服務以處理操作請求、執行業務邏輯以及在模型/資料對象上調用API。
SocialComponent API可延伸,以提供用戶端對檢視層或HTTP用戶端所需的資料。
若要自訂或擴充元件,您只會將覆蓋圖和擴充功能寫入/apps目錄,簡化升級至未來版本的程式。
該框架提供API以訪問伺服器上的功能,並支援客戶端與伺服器之間的交互。
Java API提供抽象類別和介面,這些類別和介面可輕鬆繼承或子類別。
主要類在伺服器端自訂頁面上描述。
請訪問儲存資源提供程式概述了解如何使用UGC。
HTTP API支援為PhoneGap應用程式、原生應用程式及其他整合和綜合應用程式輕鬆自訂和選擇用戶端平台。 此外,HTTP API允許社區站點作為服務運行,而無需客戶端,這樣框架元件可以整合到任何基於技術構建的任何網頁中。
架構會針對每個SocialComponent提供HTTP型API端點。 端點的存取方式為使用「.social.json」選取器+擴充功能傳送GET要求至資源。 使用Sling時,會將要求傳送至DefaultSocialGetServlet
。
DefaultSocialGetServlet
將資源(resourceType)傳遞至SocialComponentFactoryManager
並接收能夠選取代表資源的SocialComponent
的SocialComponentFactory。
調用工廠並接收能夠處理資源和請求的SocialComponent
。
叫用SocialComponent
,處理要求並傳回結果的JSON表示。
傳回JSON回應給用戶端。
GET Request
預設GETservlet監聽SocialComponent使用可自訂JSON回應的.social.json請求。
除了GET(讀取)操作外,框架還定義了端點模式以啟用元件上的其他操作,包括建立、更新和刪除。 這些端點是HTTP API,可接受輸入並以HTTP狀態代碼或JSON回應物件回應。
該框架端點模式使CUD操作可擴展、可重複使用和可測試。
POST Request
每個SocialComponent操作都有SlingPOST:操作。 每個操作的業務邏輯和維護代碼都包在OperationService中,該OperationService可通過HTTP API或從其他位置作為OSGi服務訪問。 提供了用於動作之前/之後的支援可插拔操作擴展的鈎。
若要了解如何處理儲存在社群內容存放區中的UGC,請參閱
有關自定義伺服器端Communities元件的業務邏輯和行為的資訊,請訪問伺服器端自定義。
新架構中更顯著的變更之一,是使用Handlebars JS範本語言(HBS),這是伺服器用戶端轉譯的熱門開放原始碼技術。
HBS指令碼簡單、無邏輯、在伺服器和客戶端上編譯、易於覆蓋和定制,並且自然地與客戶端UX綁定,因為HBS支援客戶端呈現。
此架構提供數個Handlebars helpers,在開發SocialComponents時相當實用。
在伺服器上,Sling解析GET請求時,會識別將用來回應請求的指令碼。 如果指令碼是HBS範本(.hbs),Sling會將要求委派給Handlebars引擎。 然後,Handlebars引擎將從適當的SocialComponentFactory中取得SocialComponent、建立內容並轉譯HTML。
Handlebars(HBS)範本檔案(.hbs)類似於.jsp和.html範本檔案,但它們可用於在用戶端瀏覽器和伺服器上呈現。 因此,請求用戶端範本的用戶端瀏覽器將從伺服器接收.hbs檔案。
這需要Sling搜尋路徑中的所有HBS範本(/libs/或/apps底下的任何.hbs檔案)可由任何使用者從製作或發佈中擷取。
不得禁止HTTP存取.hbs檔案。
大部分的Communities元件必須新增作為Sling可定址資源。 在模板中選擇的幾個Communities元件可以包括作為非現有資源,以允許動態地包含和定制寫入用戶生成內容(UGC)的位置。
無論是哪種情況,元件的必要的客戶端庫也必須存在。
新增元件
新增元件是指新增資源(元件)例項的程式,例如從元件瀏覽器(sidekick)拖曳至作者編輯模式中的頁面時。
結果會是par節點底下的JCR子節點,即Sling可定址。
包含元件
包括元件是指在範本內新增參考至"non-existing" resource(no JCR node)的程式,例如使用指令碼語言。
自AEM 6.1起,當元件以動態方式包含而非新增時,即可在製作設計模式中編輯元件的屬性。
只能動態加入少數幾個AEM Communities元件。 它們是:
社區元件指南允許切換可包含的元件,使其不被添加到要包含的元件。
使用Handlebarstemplating 語言時,會使用include helper來包含非現有資 源, 方法是指定其resourceType:
{{include this.id path="comments" resourceType="social/commons/components/hbs/comments"}}
使用JSP時,會使用標籤cq包含 資源:include:
<cq:include path="votes"
resourceType="social/tally/components/voting" />
若要動態地將元件新增至頁面,而非將元件新增或加入範本,請參閱元件側載。
有關SCF中可用的自定義幫助器的清單和說明,請參閱SCF Handlebars Helpers。
此架構包含Backbone.js的擴充功能,此為模型檢視的JavaScript架構,可協助開發豐富的互動式元件。 物件導向的性質支援可擴展/可重複使用的框架。 借由HTTP API可簡化用戶端與伺服器之間的通訊。
該框架利用伺服器端Handlebars模板來呈現客戶端的元件。 這些模型以HTTP API產生的JSON回應為基礎。 視圖將自身綁定到由Handlebars模板生成的HTML,並提供交互性。
以下是定義和使用CSS類的建議慣例:
.social-forum .topic-list .li { color: blue; }
若要自訂用戶端上Communities元件的外觀和行為,請參考用戶端自訂,其中包含下列資訊:
功能和元件要件區段中有關開發人員的基本資訊。
可在編碼指南部分找到其他開發人員資訊。
疑難排解一節將說明常見問題和已知問題。