同步最適化Forms與XFA表單範本 synchronizing-adaptive-forms-with-xfa-form-templates

Adobe 建議使用新式且可擴充的資料擷取核心元件,用來建立新的最適化表單將最適化表單新增到 AEM Sites 頁面。這些元件代表最適化表單建立方面的重大進步,可確保令人印象深刻的使用者體驗。本文會介紹使用基礎元件編寫最適化表單的舊方法。

簡介 introduction

您可以根據XFA表單範本建立最適化表單( *.XDP 檔案)。 此重複使用可讓您保留在現有XFA表單中的投資。 如需有關如何使用XFA表單範本建立調適型表單的資訊, 根據範本建立最適化表單.

您可以在最適化表單中重複使用XDP檔案中的欄位。 這些欄位稱為繫結欄位。 繫結欄位的屬性(例如指令碼、標籤和顯示格式)會從XDP檔案複製。 您也可以選擇覆寫其中某些屬性的值。

AEM Forms可協助您保持最適化表單的欄位與稍後對XDP檔案中對應欄位所做的任何變更同步。 本文會說明如何啟用此同步化。

您可以從XFA表單將欄位拖曳到最適化表單

在AEM Forms編寫環境中,您可以從XFA表單(左)將欄位拖曳到調適型表單(右)

先決條件 prerequisites

若要使用本文中的資訊,建議您熟悉下列領域:

若要使用資產提供的文章範例,請下載範例套件,如下節所述, 範例套件.

範例套件 sample-package

文章以範例示範如何將最適化表單與更新的XFA表單範本同步。 範例中使用的資產可在套件中使用,該套件可從以下網址下載: 下載 一節。

上傳套件後,您可以在AEM Forms UI中檢視這些資產。

使用封裝管理員安裝封裝: https://<server>:<port>/crx/packmgr/index.jsp

此套件包含下列資產:

  1. sample-form.xdp:當作範例使用的XFA表單範本

  2. sample-xfa-af:根據sample-form.xdp檔案的最適化表單。 不過,此最適化表單不包含任何欄位。 在下一步中,我們將新增內容至此最適化表單。

將內容新增至最適化表單 add-content-to-adaptive-form-br

  1. 導覽至https://<server>:<port>/aem/forms.html. 如有要求,請輸入您的認證。
  2. 開啟sample-af-xfa以在作者模式中編輯。
  3. 從側邊欄中的內容瀏覽器,選擇資料模型物件索引標籤。 將NumericField1和TextField1拖曳至最適化表單。
  4. 變更NumericField1的標題,從 數值欄位AF數值欄位。
NOTE
在上述步驟中,我們覆寫XDP檔案中欄位的屬性。 因此,如果稍後修改XDP檔案中的對應屬性,此屬性將不會同步。

偵測XDP檔案中的變更 detecting-changes-in-xdp-file

每當XDP檔案或片段發生任何變更時,AEM Forms UI都會標示所有以XDP檔案或片段為基礎的最適化表單。

更新XDP檔案後,您需要在AEM Forms UI中再次上傳該檔案,才能標籤變更。

例如,讓我們更新 sample-form.xdp 檔案:

  1. 瀏覽至 https://<server>:<port>/projects.html. 如果系統提示,請輸入您的認證。

  2. 按一下左側的Forms標籤。

  3. 下載 sample-form.xdp 檔案。 XDP檔案下載為 .zip 檔案,可使用任何檔案解壓縮公用程式來擷取。

  4. 開啟 sample-form.xdp 檔案並變更欄位TextField1的標題 文字欄位我的文字欄位.

  5. 上傳 sample-form.xdp 檔案傳回AEM Forms UI。

如果XDP檔案更新,當您根據XDP檔案編輯調適型表單時,會在編輯器中看到圖示。 此圖示表示最適化表單與XDP檔案不同步。 在下圖中,請參閱側邊欄中的圖示。

圖示可顯示最適化表單與XDP檔案不同步

將最適化表單與最新的XDP檔案同步 synchronizing-adaptive-forms-with-the-latest-xdp-file

下次開啟與XDP檔案不同步的適用性表單進行製作時,會顯示下列訊息: 最適化表單的資料結構/表單範本已更新。 Click Here 以使用新版本進行重設。

按一下訊息會將最適化表單中的欄位與XDP檔案中的對應欄位同步。

對於本文中使用的範例,請開啟 sample-xfa-af (在製作模式下)。 訊息會顯示在最適化表單的底部。

提示您將最適化表單與XDP檔案同步的訊息

更新屬性 updating-the-properties

從XDP檔案複製到調適型表單的所有屬性都會更新,惟作者在調適型表單(從元件對話方塊)中明確覆寫的內容除外。 伺服器記錄檔中提供已更新的屬性清單。

若要更新最適化表單範例中的屬性,請按一下連結(標籤為 "Click Here")時,不會傳送電子郵件。 TextField1的標題變更自 文字欄位我的文字欄位.

update — 屬性

NOTE
標籤AF數值欄位未變更,因為您已從元件屬性對話方塊覆寫此屬性,如中所述 將內容新增至最適化表單.

將XDP檔案的新欄位新增至最適化表單   adding-new-fields-from-xdp-file-to-adaptive-form-nbsp

任何稍後新增至原始XDP檔案的欄位都會顯示在「表單階層」標籤中,而且您可以將這些新欄位拖曳至調適型表單。

您不需要按一下錯誤訊息中的連結,即可更新表單階層標籤中的欄位。

XDP檔案中的已刪除欄位 deleted-fields-in-xdp-file

如果先前複製到調適型表單的欄位從XDP檔案中刪除,則會在編寫模式下顯示一則錯誤消息,指出該欄位在XDP檔案中不存在。 在這種情況下,請從最適化表單中手動刪除欄位或清除 bindRef 屬性。

以下步驟說明本文使用範例中資產的此使用流程:

  1. 更新 sample-form.xdp 檔案並刪除NumericField1。

  2. 上傳 sample-form.xdp AEM Forms UI中的檔案

  3. 開啟 sample-xfa-af 用於編寫的最適化表單。 會顯示下列錯誤訊息:已更新最適化表單的架構/表單範本。 Click Here 以使用新版本進行重設。

  4. 按一下連結(標示為「 Click Here")中。 系統會顯示錯誤訊息,指出欄位在XDP檔案中不再存在。

刪除XDP檔案中的元素時看到的錯誤

已刪除的欄位也會標示圖示,以指出欄位中的錯誤。

欄位中的錯誤圖示

NOTE
適用性表單中有不正確繫結(無效)的欄位 bindRef 值),也會被視為已刪除欄位。 如果作者未修正這些錯誤並發佈調適型表單,則該欄位會被視為一般未繫結的調適型表單欄位,並包含在輸出XML檔案的未繫結區段中。

下載 downloads

本文範例的Content-package

取得檔案

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2