教學課程:將規則套用至最適化表單欄位 tutorial-apply-rules-to-adaptive-form-fields
本教學課程是建立第一個最適化表單系列中的步驟。 Adobe建議您依照時間順序進行序列學習,以瞭解、執行並示範完整的教學課程使用案例。
關於教學課程 about-the-tutorial
您可以使用規則將互動性、商業邏輯和智慧型驗證新增至最適化表單。 調適型表單有內建規則編輯器。 規則編輯器提供與引導式導覽類似的拖放功能。 拖放方法是最快速且最簡單的規則建立方法。 規則編輯器也會為有興趣測試其程式碼技能或將規則提升到更高層級的使用者提供程式碼視窗。
您可以在最適化Forms規則編輯器進一步瞭解規則編輯器。
在本教學課程結束時,您將學習如何建立規則以:
- 啟動表單資料模型服務,從資料庫擷取資料
- 啟動表單資料模型服務,將資料新增至資料庫
- 執行驗證檢查並顯示錯誤訊息
教學課程每個區段結尾的互動式GIF影像可協助您即時學習及驗證您所建置表單的功能。
步驟1:從資料庫擷取客戶記錄 retrieve-customer-record
您已依照建立表單資料模型文章建立表單資料模型。 現在,您可以使用規則編輯器來叫用Forms資料模型服務,以擷取資訊並新增至資料庫。
每個客戶都會獲派一個唯一的客戶ID號碼,這有助於識別資料庫中的相關客戶資料。 下列程式使用客戶ID從資料庫擷取資訊:
-
開啟最適化表單進行編輯。
http://localhost:4502/editor.html/content/forms/af/change-billing-shipping-address.html
-
選取 客戶識別碼 欄位,並選取 編輯規則 圖示。 「規則編輯器」視窗隨即開啟。
-
選取「+建立」圖示以新增規則。 這會開啟視覺化編輯器。
在視覺化編輯器中,預設會選取 WHEN 陳述式。 此外,WHEN 陳述式中會指定您啟動規則編輯器的表單物件(在此案例中為 客戶識別碼)。
-
選取 選取狀態 下拉式清單,並選取 已變更。
-
在 THEN 陳述式中,從 選取動作 下拉式清單中選取 叫用服務。
-
從 選取 下拉式清單中選取 擷取送貨地址 服務。
-
從[表單物件]索引標籤將 客戶識別碼 欄位拖放到 拖放物件,或在 輸入 方塊中選取這裡 欄位。
-
從[表單物件]索引標籤將 客戶ID、名稱、送貨地址、狀態和郵遞區號 欄位拖放到 放置物件,或在 輸出 方塊中選取這裡 欄位。
選取 完成 以儲存規則。 在規則編輯器視窗中,選取 關閉。
-
預覽最適化表單。 在 客戶識別碼 欄位中輸入ID。 該表單現在可以從資料庫擷取客戶詳細資訊。
步驟2:將更新的客戶地址新增至資料庫 updated-customer-address
從資料庫擷取客戶詳細資料後,您可以更新送貨地址、州別和郵遞區號。 下列程式會叫用「表單資料模型」服務,將客戶資訊更新至資料庫:
-
選取 提交 欄位並選取 編輯規則 圖示。 「規則編輯器」視窗隨即開啟。
-
選取 提交 — 按一下 規則並選取 編輯 圖示。 編輯提交規則的選項隨即顯示。
在WHEN選項中,已選取 已點按 及 已點按 選項。
-
在 THEN 選項中,選取 +新增陳述式 選項。 從 選取動作 下拉式清單中選取 啟動服務。
-
從 選取 下拉式清單中選取 更新送貨地址 服務。
-
從表單物件索引標籤將 送貨地址、狀態和郵遞區號 欄位拖放到 Drop物件的對應tablename .property (例如customerdetails .shippingAddress),或在 INPUT 方塊中選取這裡 欄位。 所有前置詞為tablename的欄位(例如,在此使用案例中為customerdetails)都會當作更新服務的輸入資料。 這些欄位中提供的所有內容都會在資料來源中更新。
note note NOTE 請勿將 Name 和 客戶ID 欄位拖放至對應的tablename.property (例如customerdetails.name)。 它有助於避免錯誤地更新客戶的名稱和ID。 -
將 客戶ID 欄位從表單物件標籤拖放至 輸入 方塊中的ID欄位。 沒有前置字元Tablename的欄位(例如,此使用案例中的Customerdetails)會作為更新服務的搜尋引數。 此使用案例中的 id 欄位可唯一識別 customerdetails 資料表中的記錄。
-
選取 完成 以儲存規則。 在規則編輯器視窗中,選取 關閉。
-
預覽最適化表單。 擷取客戶的詳細資料、更新送貨地址並提交表單。 當您再次擷取相同客戶的詳細資料時,會顯示更新的送貨地址。
步驟3: (額外區段)使用程式碼編輯器執行驗證並顯示錯誤訊息 step-bonus-section-use-the-code-editor-to-run-validations-and-display-error-messages
您應該對表單執行驗證,以確保在表單中輸入的資料正確無誤,並且在資料不正確時會顯示錯誤訊息。 例如,如果在表單中輸入不存在的客戶ID,則會顯示錯誤訊息。
調適型表單提供具備內建驗證的元件,例如電子郵件和數值欄位,您可將其用於常見使用案例。 針對進階使用案例,使用規則編輯器,例如在資料庫傳回零(0)筆記錄(無記錄)時,顯示錯誤訊息。
下列程式說明如果表單中輸入的客戶ID不存在於資料庫中,如何建立規則以顯示錯誤訊息。 此規則也會將焦點帶到 客戶ID 欄位並重設。 規則使用表單資料模型服務🔗的dataIntegrationUtils API來檢查資料庫中是否有客戶ID。
-
選取 客戶識別碼 欄位,並選取
Edit Rules
圖示。 規則編輯器視窗隨即開啟。 -
選取「+建立」圖示以新增規則。 這會開啟視覺化編輯器。
在視覺化編輯器中,預設會選取 WHEN 陳述式。 此外,WHEN 陳述式中會指定您啟動規則編輯器的表單物件(在此案例中為 客戶識別碼)。
-
選取 選取狀態 下拉式清單,並選取 已變更。
在 THEN 陳述式中,從 選取動作 下拉式清單中選取 叫用服務。
-
從 視覺化編輯器 切換至 程式碼編輯器。 切換器控制項位於視窗的右側。 程式碼編輯器隨即開啟,顯示類似下列的程式碼:
-
將輸入變數區段取代為下列程式碼:
code language-javascript var inputs = { "id" : this };
-
以下列程式碼取代
guidelib.dataIntegrationUtils.executeOperation (operationInfo, inputs, outputs)
區段:code language-javascript guidelib.dataIntegrationUtils.executeOperation(operationInfo, inputs, outputs, function (result) { if (result) { result = JSON.parse(result); customer_Name.value = result.name; customer_Shipping_Address = result.shippingAddress; } else { if(window.confirm("Invalid Customer ID. Provide a valid customer ID")) { customer_Name.value = " "; guideBridge.setFocus(customer_ID); } } });
-
預覽最適化表單。 輸入不正確的客戶ID。 出現錯誤訊息。