HTML5表單常見問題集(FAQ) frequently-asked-questions-faq-for-html-forms

關於版面配置、指令碼支援和HTML5表單的範圍有一些常見問題(FAQ)。

版面配置 layout

  1. 中的條碼和簽名欄位為何沒有出現在我的表單中?

    答案:條碼和簽名欄位在HTML或行動情況中並不相關。 這些欄位會顯示為非互動區域。 不過,AEM Forms Designer提供新的簽名草寫欄位,可用來取代簽名欄位。 您也可以新增 自訂Widget 並加以整合。

  2. XFA文字欄位是否支援RTF格式?

    回答: XFA欄位允許AEM Forms Designer中的豐富內容,但不受支援,而且會呈現為一般文字,不支援從使用者介面為文字設定樣式。 此外,具有梳狀屬性的XFA欄位會顯示為一般欄位,不過根據梳狀位數的值,還是會有允許字元數的限制。

  3. 使用可重複的子表單是否有任何限制?

    回答:可重複的子表單應該有1個或多個初始計數。 不支援初始計數為零的可重複子表單。 您也可以選擇使用可重複的子表單,而在載入表單時不要顯示它。 若要實現使用案例:

    1. 將可重複子表單的初始計數設為1。

      初始計數

    2. 使用表單的初始化事件來隱藏子表單的主要執行個體。 例如,下列程式碼會在表單初始化時隱藏子表單的主要例項。 它也會驗證應用程式型別,以確保指令碼僅在使用者端上執行:

      code language-javascript
      if ((xfa.host.appType == "HTML 5" || xfa.host.appType == "Exchange-Pro" || xfa.host.appType == "Reader")&&(_RepeatSubform.count == 1)&&(form1.Page1.Subform1.RepeatSubform.Key.rawValue == null)) {
      RepeatSubform.presence = "hidden";
      }
      
    3. 開啟指令碼,以新增要編輯的子表單例項。 新增如下程式碼以新增Subform指令碼的例項。

      以下程式碼會檢查子表單的隱藏執行個體。 如果找到子表單的隱藏實體,請刪除子表單的隱藏實體並插入新的子表單實體。 如果找不到子表單的隱藏實體,則只需插入新的子表單實體即可。

      code language-javascript
      if (RepeatSubform.presence == "hidden")
      {
      RepeatSubform.instanceManager.insertInstance(0);
      RepeatSubform.instanceManager.removeInstance(1);
      }
      else
      {
      RepeatSubform.instanceManager.addInstance(1);
      }
      
    4. 開啟指令碼,移除要編輯的子表單執行個體。 新增如以下的程式碼,以移除Subform指令碼的例項。

      程式碼會檢查子表單的計數。 如果子表單的計數達到1,則程式碼會隱藏子表單,而不是刪除子表單。

      code language-javascript
      if (RepeatSubform.instanceManager.count == 1) {
      RepeatSubform.presence = "hidden";
      } else {
      RepeatSubform.instanceManager.removeInstance(RepeatSubform.instanceManager.count - 1);
      }
      
    5. 開啟表單的預先提交事件以進行編輯。 將下列指令碼新增至事件,以在編輯前移除指令碼的隱藏實體。 它可防止在提交時傳送隱藏子表單的資料。

      code language-javascript
      if(RepeatSubform.instanceManager.count == 1 && RepeatSubform.presence == "hidden") {
      RepeatSubform.instanceManager.removeInstance(0);
      }
      
  4. 關於使用隱藏的子表單是否有任何限制?

    答案:具有複雜階層的隱藏子表單分割成不同頁面,會造成版面配置問題。 因應措施是最初將子表單標示為可見,然後根據某些邏輯或資料將其隱藏在初始化指令碼中。

  5. 為什麼某些文字被截斷或在HTML5中顯示不正確?

    回答:如果Draw或Caption文字元素沒有足夠的空間顯示內容,行動表單轉譯中的文字會顯示為截斷。 AEM Forms Designer的「設計」檢視中也會顯示此截斷。 雖然此截斷可在PDF中處理,但無法在HTML5表單中處理。 若要避免此問題,請為繪製或標題文字提供足夠的空間,使其在AEM Forms Designer的設計模式中不會截斷。

  6. 我觀察到與缺少內容或重疊內容相關的版面配置問題。 原因是什麼?

    回答:如果在相同位置有「繪製文字」或「繪製影像」元素以及其他重疊元素(例如「矩形」),如果「繪製文字」內容在檔案順序中較晚出現(在「AEM Forms Designer階層」檢視中),則不會顯示「繪製文字」內容。 PDF支援透明分層,但HTML/瀏覽器不支援透明分層。

  7. 為什麼在HTML表單中顯示的某些字型與設計表單時使用的字型不同?

    回答:HTML5 Forms不允許內嵌字型(與將字型內嵌在表單中的PDF forms相反)。 為了讓表單的HTML版本如預期般呈現,請確定AEM Forms伺服器的CRX存放庫(AEM內容存放庫)中以及安裝AEM Designer的電腦上都有這些字型。 當AEM Forms伺服器的CRX存放庫或AEM Designer安裝位置中無法使用字型時,表單會以備援字型呈現。

  8. HTML表單中是否支援vAlign和hAlign屬性?

    回答:是,支援vAlign和hAlign屬性。 Internet Explorer和多行欄位中不支援vAlign屬性。

  9. HTML5表單是否支援希伯來字元?

    回答:HTML5表單在Microsoft Internet Explorer以外的所有瀏覽器中均支援希伯來字元。

  10. HTML5表單對數值欄位有任何限制嗎?

    回答:是,HTML5表單有幾項限制。 如果位數超過picture子句中指定的計數,則數字不會本地化,且會以英文語言環境顯示。

  11. 為何HTML表單的大小比PDF forms大?

    回答:許多中繼資料結構和物件(例如表單dom、資料dom和版面dom)都是將XDP轉譯為HTML表單所必需。

    對於PDF forms,Adobe Acrobat有內建的XTG引擎可建立中繼資料結構和物件。 Acrobat也會處理版面和指令碼。

    對於HTML5表單,瀏覽器沒有內建的XTG引擎來從原始XDP位元組建立中間資料結構和物件。 因此,對於HTML5表單,會在伺服器上產生中間結構並傳送給使用者端。 在使用者端,以JavaScript為基礎的指令碼和版面引擎會使用這些中間結構。

    中間結構的大小取決於原始XDP和與XDP合併的資料的大小。

  12. 在xdp中使用表格是否有任何限制?

    回答:複雜的表格會導致轉譯時發生問題。

    • 不支援表格內的區段(SubformSet)。
    • 某些表格的頁首或頁尾列會標示為重複。 在多個頁面上分割這類表格可能會發生一些問題。
  13. 可存取的表格是否有任何限制?

    回答:是,可存取的表格有下列限制:

    • 不支援表格內的巢狀表格和子表單。

    • 只有表格的頂端列或左側欄支援標題。 中間表格元素不支援標題。 如果所有列和欄與表格最上層的列或最左邊的欄一起使用,則可將標題套用至多個支援的列和欄標題。

    • Rowspancolspan不支援來自表格內的隨機位置。

    • 您無法動態新增或移除包含rowspan值大於1之元素的資料列例項。

  14. 熒幕助讀程式的工具提示和註解閱讀順序為何?

    回答:

    • 當註解與工具提示同時出現時,只會讀取註解。 如果註解無法使用,則會讀取工具提示。 您也可以使用表單設計工具來指定在XDP中讀取的優先順序
    • 當您將滑鼠懸停在元素上時,會顯示工具提示。 如果無法使用工具提示,則會顯示語音文字。 如果語音文字無法使用,則會顯示欄位名稱。
  15. 當您將滑鼠懸停在欄位上時,會顯示工具提示。 如何加以停用?

    回答:若要在游標停留時停用工具提示,請在「設計工具」的協助工具面板中選取「無」。

  16. 在Designer中,使用者可以設定選項按鈕和核取方塊的自訂外觀屬性。 轉譯表單時,HTML5表單會將此類自訂外觀屬性納入考量嗎?

    回答:HTML5表單忽略選項按鈕和核取方塊的自訂外觀屬性。 選項按鈕和核取方塊會根據基礎瀏覽器的規格顯示。

  17. 在支援的瀏覽器中開啟HTML5表單時,相鄰放置欄位的邊框未正確對齊,或子表單出現重疊。 在Forms Designer中預覽相同的HTML5表單時,欄位和版面不會出現未對齊的情況,而子表單會出現在正確位置。 如何修正問題?

    回答:當子表單設定為流程內容且子表單有隱藏的邊框元素時,相鄰放置欄位的邊框未正確對齊或子表單出現重疊。 若要解決此問題,您可以移除或註解隱藏的 <border> 元素。 例如,下列專案 <border> 元素會標示為註解:

    code language-xml
                <!--<border>
                   <edge presence="hidden"/>
                   <corner thickness="0.175mm" presence="hidden"/>
                </border> -->
    
  18. 為什麼熒幕助讀程式無法正確搭配日期/時間欄位物件運作?

    答案:熒幕助讀程式不支援日期/時間欄位。 不過,您可以手動在欄位中輸入日期/時間,讓熒幕助讀程式閱讀此欄位。 使用工具提示或熒幕助讀程式文字來指示使用者手動選取欄位的日期/時間。

  19. HTML5表單是否支援浮動欄位的顯示模式?

    答案:HTML5表單不支援浮動欄位的顯示模式。

  20. HTML5 Forms中「日期」欄位的格式為何?

答案:「日期」欄位接受ISO格式YYYY-MM-DD。 如果您以其他格式指定日期,在使用者以定位點移出欄位之前,「日期欄位」不接受格式。

指令碼 scripting

  1. HTML Forms的JavaScript實施是否有任何限制?

    回答:

    • xfa.connectionSet指令碼的支援有限。 對於connectionSet,僅支援伺服器端對Web服務的呼叫。 如需詳細資訊,請參閱 指令碼支援.
    • 使用者端指令碼中不支援$record和$data。 不過,如果指令碼是以formReady, layoutReady區塊撰寫,則這些指令碼仍然有效,因為這些事件會在伺服器端執行。
    • 不支援XFA Draw元素特定的指令碼,例如變更Draw文字(如果有欄位,則為標題文字)。
  2. 使用formCalc是否有任何限制?

    回答:目前僅實作formCalc指令碼的子集。 如需詳細資訊,請參閱 指令碼支援.

  3. 是否有任何建議的命名慣例,以及任何要避免的保留關鍵字?

    回答:

    • 在AEM Forms Designer中,建議不要以底線()。 若要在名稱開頭使用底線,請在底線後加上首碼,<prefix><objectname>.
    • 所有HTML5 Forms API都是保留關鍵字。 對於自訂API/函式,請使用與不同的名稱 HTML5 forms API.
  4. HTML5表單是否支援浮動欄位?

    回答:是,HTML5 Forms支援浮動欄位。 若要啟用浮動欄位,請將下列屬性新增至演算設定檔:

    note note
    NOTE
    依預設,這些欄位不會啟用浮動功能。 您可以使用Forms Designer來設定欄位的浮動屬性。
    1. 開啟CRXde Lite並導覽至 /content/xfaforms/profiles/default 節點。

    2. 新增屬性 mfDataDependentFloatingField字串型別的屬性,並將屬性的值設為 true.

    3. 按一下 全部儲存. 現在已使用更新後的轉譯設定檔,為HTMLForms啟用浮動欄位。

      note note
      NOTE
      若要在不更新轉譯設定檔的情況下啟用特定表單的浮動欄位,請傳遞mfDataDependentFloatingField=true屬性做為URL引數。
  5. HTML5表單會多次執行初始化指令碼和表單就緒事件嗎?

    回答:是,初始化指令碼和表單就緒事件會執行多次,在伺服器上至少執行一次,在使用者端執行一次。 建議根據某些商業邏輯(表單或欄位資料)編寫初始化或表單:ready事件等指令碼,以便根據資料和等冪狀態(如果資料相同)執行動作。

設計XDP designing-xdp

  1. HTML5表單中是否有任何保留關鍵字?

    回答:所有HTML5 Forms API都是保留關鍵字。 對於自訂API/函式,請使用與不同的名稱 HTML5 forms API. 除了保留的關鍵字之外,如果您使用以底線(_)開頭的物件名稱,建議在底線後新增唯一的前置詞。 新增首碼有助於避免與HTML5表單內部API發生任何可能的衝突。 例如 _fpField1

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