Show Menu
主題×

使用表單資料模型

「資料整合」提供表單資料模型編輯器,以設定和使用表單資料模型。
表單資料模型編輯器提供直覺式使用者介面和工具,以編輯和設定表單資料模型。 使用編輯器,您可以在表單資料模型中,從相關資料來源新增及設定資料模型物件、屬性和服務。 此外,它還可讓您建立資料模型物件和屬性,毋需使用資料來源,並在稍後以個別的資料模型物件和屬性加以系結。 您也可以針對資料模型物件屬性產生和編輯範例資料,以便在預覽時用來預先填寫最適化表單和互動式通訊。 您可以測試在表單資料模型中設定的資料模型物件和服務,以確保它與資料來源正確整合。
如果您是Forms資料整合的新手,但尚未設定資料來源或建立表單資料模型,請參閱下列主題:
請參閱,以取得有關您可以使用表單資料模型編輯器執行之各種工作和設定的詳細資訊。
您必須是 fdm-author和 forms-user ​組的成員,才能建立和使用表單資料模型。 請連絡您的AEM管理員,以成為群組的成員。

新增資料模型物件和服務

如果您使用資料來源建立表單資料模型,則可使用表單資料模型編輯器來新增資料模型物件和服務、設定其屬性、建立資料模型物件之間的關聯,以及測試表單資料模型和服務。
您可以從可用資料來源以資料模型的形式新增資料模型物件和服務。 添加的資料模型對象顯示在「模型」頁籤中,添加的服務顯示在「服務」頁籤中。
要添加資料模型對象和服務:
  1. 登入AEM作者例項、導覽至「 Forms > Data Integrations 」,並開啟您要在其中新增資料模型物件的表單資料模型。
  2. 在「資料來源」窗格中,展開資料來源以檢視可用的資料模型物件和服務。
  3. 選擇要添加到表單資料模型的資料模型對象和服務,並點選「添加選 定項」
    「模型」(Model)頁籤顯示所有資料模型對象及其添加到表單資料模型的屬性的圖形表示。 每個資料模型對象由表單資料模型中的框表示。
    您可以按住並拖曳資料模型物件方塊,以在內容區域中組織它們。 在「資料來源」窗格中,表格資料模型中新增的所有資料模型物件都會變灰。
    「服務」標籤列出新增的服務。
    除了資料模型對象和服務外,OData服務元資料文檔還包括定義兩個資料模型對象之間的關聯的導航屬性。 有關詳細資訊,請參 閱使用OData服務的導航屬性
  4. 點選「 儲存 」以儲存表單模型物件。
    您可以使用自適應表單規則來調用在表單資料模型的「服務」頁籤中配置的服務。 規則編輯器的「調用服務」操作中提供了已配置的服務。有關在自適應表單規則中使用這些服務的詳細資訊,請參閱規則編輯器中的調用服務和設定規 則值

建立資料模型對象和子屬性

建立資料模型物件

雖然您可以從已設定的資料來源新增資料模型物件,但您也可以建立沒有資料來源的資料模型物件或實體。 尤其當您未在表單資料模型中設定資料來源時,這會很有幫助。
要建立沒有資料源的資料模型對象,請執行以下操作:
  1. 登入AEM作者例項、導覽至「 Forms > Data Integrations 」,並開啟您要在其中建立資料模型物件或實體的表單資料模型。
  2. 點選「 建立實體 」。
  3. 在「建立資料模型」(Create data Model)對話框中,指定資料模型對象的名稱並點選「添 加」(Add )。 資料模型對象被添加到表單資料模型中。 請注意,新添加的資料模型對象不綁定到資料源,並且沒有任何屬性,如下圖所示。
接下來,可以在未綁定的資料模型對象中添加子屬性。

添加子屬性

表單資料模型編輯器允許您在資料模型對象中建立子屬性。 建立時的屬性不會綁定到資料源中的任何屬性。 您稍後可以在包含資料模型對象中將子屬性與另一個屬性綁定。
要建立子屬性:
  1. 在表單資料模型中,選取資料模型物件並點選「建 立子屬性」
  2. 在「創 建子屬性 」對話框中,分別在「名稱」和「類型」欄位中為屬性指定名稱 和資料類型。 您可以選擇指定屬性的標題和說明。
  3. 如果屬性是計算屬性,則啟用計算。 計算屬性的值會根據規則或運算式來評估。 如需詳細資訊,請參閱 編輯屬性
  4. 如果資料模型對象綁定到資料源,則添加的子屬性將自動綁定到具有相同名稱和資料類型的父資料模型對象的屬性。
    若要手動將子屬性與資料模型物件屬性系結,請點選「系結參考」欄位旁 的瀏覽圖示 。 「選 擇對象 」(Select Object)對話框列出父資料模型對象的所有屬性。 選取要系結的屬性並點選勾選圖示。 請注意,您只能選擇與子屬性具有相同資料類型的屬性。
  5. 點選 「完成 」以儲存子屬性,點選「 儲存 」以儲存表單資料模型。 子屬性現在會新增至資料模型物件。
在建立資料模型物件和屬性後,您可以繼續根據表單資料模型建立最適化表單和互動式通訊。 之後,當您有可用的資料來源並加以設定時,您就可以將表單資料模型與資料來源系結。 系結會自動在相關的調適性表單和互動式通訊中更新。 如需有關使用表單資料模型建立自適應表單和互動式通訊的詳細資訊,請參 閱使用表單資料模型

綁定資料模型對象和屬性

當您要與表單資料模型整合的資料來源可供使用時,您可以將其新增至表單資料模型,如「更新資料來源」中 所述 。 然後,執行下列動作來系結未系結的資料模型物件和屬性:
  1. 在表單資料模型中,選取您要與資料來源系結的未系結資料來源。
  2. 點選「 編輯屬性 」。
  3. 在「編 輯屬性 」窗格中,點選「系結」欄位旁的 瀏覽圖示 。 它會開啟「選 取物件 」對話方塊,列出在表單資料模型中新增的資料來源。
  4. 展開資料來源樹狀結構,並選取要與勾選圖示系結的資料模型物件。
  5. 點選 「完成 」以儲存屬性,然後點選「 儲存 」以儲存表單資料模型。 資料模型物件現在會與資料來源系結。 請注意,資料模型物件不再標示為「未系結」。

設定服務

要讀取和寫入資料模型對象的資料,請執行以下操作以配置讀取和寫入服務:
  1. 選中資料模型對象頂部的複選框以將其選中,然後點選「編輯屬 性」
    編輯屬性以配置資料模型對象的讀和寫服務
    「編輯屬性」(Edit Properties)對話框隨即開啟。
    編輯屬性對話框
    除了資料模型對象和服務外,OData服務元資料文檔還包括定義兩個資料模型對象之間的關聯的導航屬性。 將OData服務資料源添加到表單資料模型時,表單資料模型中有一個服務可用於資料模型對象中的所有導航屬性。 您可以使用此服務讀取相應資料模型對象的導航屬性。
    有關使用服務的詳細資訊,請參 閱使用OData服務的導航屬性
  2. 切換 頂層物件 ,以指定資料模型物件是否為頂層模型物件。
    在表單資料模型中配置的資料模型對象可用於基於表單資料模型的自適應表單的內容瀏覽器中的「資料模型對象」頁籤。 在兩個資料模型對象之間添加關聯時,與關聯的資料模型對象在「資料模型對象」(Data Model Objects)頁籤中關聯的資料模型對象下嵌套。 如果巢狀資料模型是頂層對象,它也將單獨顯示在「資料模型對象」(Data Model Objects)頁籤中。 因此,您會看到其中兩個項目,一個在巢狀階層內,另一個在巢狀階層外,這可能會混淆表單作者。 要使關聯的資料模型對象僅顯示在嵌套層次中,請禁用「頂層對象」屬性。
  3. 為所選資料模型對象選擇「讀取和寫入服務」。 服務的引數隨即出現。
    為員工資料源配置的讀寫服務
  4. 點選 ,以讀取服務引數,將引數系結至「使用者描述檔屬性」、「請求屬性」或「常值」值,並指定系結值。 它將服務引數綁定到指定的綁定屬性或常值,該值作為參數傳遞給服務,以從資料源中獲取與指定值相關聯的詳細資訊。
    在此示例中,引 id 數將採用用戶配置檔案的屬 empid 性的值,並將其作為參數傳遞給讀取服務。 它將從指定的資料模型對象讀取和返回 employee 相關屬性的值 empid 。 因此,如果您在表單欄位中指 empid 定00250,讀取服務將會讀取員工ID為00250的詳細資料。
    此外,還可以使參數為強制或可選。
    將id引數系結至AEM使用者設定檔的empid屬性
  5. 選「完成 」以儲存引數,點選「完成 」以儲存屬性,然後點選「儲存 」以儲存表單資料模型。

新增關聯

通常,資料源中的資料模型對象之間會建立關聯。 關聯可以是一對一或一對多。 例如,可以有多個與員工關聯的家屬。 它被稱為一對多關聯,由連接關聯資料模型對 1:n 像的線上描述。 但是,如果關聯為給定的員工ID返回唯一的員工名稱,則稱為一對一關聯。
將資料源中的關聯資料模型對象添加到表單資料模型時,它們的關聯將保留並顯示為通過箭頭線連接。 您可以在表單資料模型中,跨不同資料來源新增資料模型物件之間的關聯。
JDBC資料源中的預定義關聯不會保留在表單資料模型中。 您必須手動建立。
要添加關聯,請:
  1. 選取資料模型物件頂端的核取方塊,以選取它並點選「新增關 聯」 。 將開啟「添加關聯」對話框。
    除了資料模型對象和服務外,OData服務元資料文檔還包括定義兩個資料模型對象之間的關聯的導航屬性。 在表單資料模型中新增關聯時,可使用這些導覽屬性。 有關詳細資訊,請參 閱使用OData服務的導航屬性
    將開啟「添加關聯」對話框。
    「添加關聯」對話框
  2. 在「添加關聯」窗格中:
    • 指定關聯的標題。
    • 選擇關聯類型— 一對一或一對多。
    • 選擇要與關聯的資料模型對象。
    • 選擇讀取服務以從所選模型對象讀取資料。 將顯示讀取服務參數。 編輯以變更引數(如有必要),並將其系結至資料模型物件的屬性以建立關聯。
    在以下示例中,Dependents資料模型對象的讀取服務的預設參數為 dependentid
    Dependents讀取服務的預設參數為dependentid
    但是,參數必須是關聯資料模型對象之間的公用屬性,在本例中為 Employeeid 。 因此,必 Employeeid 須將引數綁定到Employee資料模型對 id 像的屬性,以從Dependents資料模型對象中獲取相關的依存對象詳細資訊。
    更新的引數和系結
    點選 「完成 」以儲存引數。
  3. 點選 「完成 」以儲存關聯,然後點選「 儲存 」以儲存表單資料模型。
  4. 重複步驟,視需要建立更多關聯。
添加的關聯會以指定的標題和連接關聯資料模型對象的一行出現在資料模型對象框中。
您可以通過選中與之對應的複選框來編輯關聯,然後點選「編 輯關聯」

編輯屬性

您可以編輯資料模型對象的屬性、其屬性以及在表單資料模型中添加的服務。
要編輯屬性:
  1. 選中資料模型對象、屬性或表單資料模型中服務旁邊的複選框。
  2. 點選「 編輯屬性 」。 將打 開選定模型對象 、屬性或服務的「編輯屬性」窗格。
    • 資料模型物件 :指定讀寫服務並編輯引數。
    • 屬性 :指定屬性的類型、子類型和格式。 您也可以指定所選屬性是否為資料模型對象的主鍵。
    • 服務 :指定服務的輸入模型對象、輸出類型和參數。 對於Get服務,您可以指定是否需要返回陣列。
    獲取服務的編輯屬性對話框
  3. 點選 「完成 」以儲存屬性,然後點選「 儲存 」以儲存表單資料模型。

建立計算屬性

計算屬性是根據規則或表達式計算其值的屬性。 使用規則,可以將計算屬性的值設定為文本字串、數字、數學表達式的結果或表單資料模型中其他屬性的值。
例如,您可以建立計算屬性 FullName ,其值是現有 FirstName ​LastName屬性串連的結果。 若要這麼做:
  1. 使用其資料類型為「字串」 FullName 的名稱建立新屬性。
  2. 啟用 Computed ,並點選 Done 以建立屬性。
    將建立FullName計算屬性。 請注意屬性旁的圖示,以描繪計算屬性。
  3. 選擇FullName屬性,然後點選「編 輯規則」 。 規則編輯器窗口隨即開啟。
  4. 在規則編輯器視窗中,點選「 建立」 。 將開啟 「設定值 」規則窗口。
    從「選擇選項」下拉式清單中,選取「數學 運算式」 。 其他可用選項 是「表單資料模型物件 和「字串」
  5. 在數學表達式中,分別 在第一個和第 二個對象中選擇FirstName LastName。 選擇 加號 作為運算子。
    點選 「完成 」,然後點選「 關閉 」以關閉規則編輯器視窗。 規則看起來類似下列。
  6. 在表單資料模型上,點選「 儲存」 。 已配置計算屬性。

使用OData服務的導航屬性

在OData服務中,導航屬性用於定義兩個資料模型對象之間的關聯。 這些屬性是在實體類型或複雜類型上定義的。 例如,在以下 TripPin OData範例服務的中繼資料檔案摘取中,人員實體包含三個導覽屬性:朋友、BestFriend和旅行。
如需導覽屬性的詳細資訊,請參閱 OData檔案
<edmx:Edmx xmlns:edmx="https://docs.oasis-open.org/odata/ns/edmx" Version="4.0">
<script/>
<edmx:DataServices>
<Schema xmlns="https://docs.oasis-open.org/odata/ns/edm" Namespace="Microsoft.OData.Service.Sample.TrippinInMemory.Models">
<EntityType Name="Person">
<Key>
<PropertyRef Name="UserName"/>
</Key>
<Property Name="UserName" Type="Edm.String" Nullable="false"/>
<Property Name="FirstName" Type="Edm.String" Nullable="false"/>
<Property Name="LastName" Type="Edm.String"/>
<Property Name="MiddleName" Type="Edm.String"/>
<Property Name="Gender" Type="Microsoft.OData.Service.Sample.TrippinInMemory.Models.PersonGender" Nullable="false"/>
<Property Name="Age" Type="Edm.Int64"/>
<Property Name="Emails" Type="Collection(Edm.String)"/>
<Property Name="AddressInfo" Type="Collection(Microsoft.OData.Service.Sample.TrippinInMemory.Models.Location)"/>
<Property Name="HomeAddress" Type="Microsoft.OData.Service.Sample.TrippinInMemory.Models.Location"/>
<Property Name="FavoriteFeature" Type="Microsoft.OData.Service.Sample.TrippinInMemory.Models.Feature" Nullable="false"/>
<Property Name="Features" Type="Collection(Microsoft.OData.Service.Sample.TrippinInMemory.Models.Feature)" Nullable="false"/>
<NavigationProperty Name="Friends" Type="Collection(Microsoft.OData.Service.Sample.TrippinInMemory.Models.Person)"/>
<NavigationProperty Name="BestFriend" Type="Microsoft.OData.Service.Sample.TrippinInMemory.Models.Person"/>
<NavigationProperty Name="Trips" Type="Collection(Microsoft.OData.Service.Sample.TrippinInMemory.Models.Trip)"/>
</EntityType>

當您在表單資料模型中設定OData服務時,實體容器中的所有導覽屬性都可透過表單資料模型中的服務取得。 在此TripPin OData服務範例中,實體容器中的三個導覽屬性 Person 可使用表單資料模型中 GET LINK 的一個服務來讀取。
以下摘要說 GET LINK of Person /People 明表單資料模型中的服務,此服務是TripPin OData服務實體中三個導覽屬 Person 性的組合服務。
將服務添加到 GET LINK 「表單資料模型」中的「服務」頁籤後,可以編輯屬性以選擇要在服務中使用的輸出模型對象和導航屬性。 例如,以下示例中 GET LINK of Person /People 的以下服務使用Trip作為輸出模型對象,導航屬性使用Trips。
NavigationPropertyName參數的 Default Value (預設值)欄位中可 用的值取決於Return陣列 的狀態? 切換按鈕。 啟用後,會顯示系列類型的導覽屬性。
在此示例中,您也可以選擇輸出模型對象作為Person,並選擇導航屬性參數作為Friends或BestFriend(取決於 Return陣列? 啟用或停用)。
同樣地,在表單資料模 GET LINK 型中新增關聯時,您可以選擇服務並設定其導覽屬性。 不過,若要能夠選取導覽屬性,請確定「系結至」 欄位已設 為「常 值」

產生和編輯範例資料

表單資料模型編輯器允許您在表單資料模型中為所有資料模型對象屬性生成示例資料,包括計算屬性。 它是一組隨機值,符合為每個屬性設定的資料類型。 您也可以編輯和儲存資料,即使重新產生範例資料,也會保留這些資料。
執行下列動作以產生和編輯範例資料:
  1. 開啟表單資料模型,並點選「編 輯範例資料」 。 它會在「編輯樣本資料」窗口中生成並顯示樣本資料。
  2. 在「編 輯範例資料 」視窗中,視需要編輯資料,然後點選「 儲存」
接下來,您可以使用範例資料,根據表單資料模型來預先填寫和測試互動式通訊。 如需詳細資訊,請參 閱使用表單資料模型

測試資料模型物件和服務

您的表單資料模型已設定,但在投入使用前,您可能想要測試已設定的資料模型物件和服務是否如預期般運作。 要測試資料模型對象和服務:
  1. 在表單資料模型中選取資料模型物件或服務,並分別點選「 Test Model Object 或「Test Service 」。
    將開啟「測試表單資料模型」窗口。
  2. 在「測試表單資料模型」窗口中,從「輸入」窗格中選擇要測試的資料模型對象或服務。
  3. 在測試程式碼中指定引數值,然後點選「 測試」 。 成功的測試會傳回「輸出」窗格中的輸出。
同樣地,您可以測試表單資料模型中的其他資料模型物件和服務。

後續步驟

您有一個工作表單資料模型,現在可以在最適化表單和互動式通訊工作流程中使用。 如需詳細資訊,請參 閱使用表單資料模型