バージョン | 記事リンク |
---|---|
AEM 6.5 | ここをクリックしてください |
AEM as a Cloud Service | この記事 |
繰り返し可能なセクションとは、同じデータの複数のインスタンスに関する情報を収集するために、複製または繰り返し実行できるフォームの一部を指します。
例えば、ある人物の職歴に関する情報を収集するために使用するフォームについて考えてみましょう。前の各職務の詳細を取得するための繰り返し可能なセクションがある場合があります。繰り返し可能なセクションには、通常、会社名、役職、雇用日、職務責任などのフィールドが含まれます。繰り返し可能なセクションの複数のインスタンスを追加して、保持している各ジョブに関する情報を入力できます。
この記事を最後まで読むと、以下の操作を実行できるようになります。
パネル、アコーディオン、水平タブ、またはウィザードコンポーネントを使用して、アダプティブフォームのセクションを繰り返し可能にすることができます。パネル、アコーディオン、水平タブ、またはウィザードコンポーネントに子コンポーネントを追加して、フォーム内に繰り返し可能なセクションを作成できます。
このドキュメントの例は、パネルコンポーネントに基づいています。同じ手順を実行して、アコーディオン、水平タブ、およびウィザードコンポーネントを繰り返すことができます。
フォーム内でパネルを繰り返したり、繰り返し可能なパネルを削除したりする場合、フォーム作成者はボタンコンポーネントを使用してパネルのインスタンスを追加または削除します。フォームに繰り返し可能なセクション(パネル)を追加または削除するには、次の手順を実行します。
パネルを繰り返し可能にするには、次の手順を実行します。
パネルコンテナを選択し、「 」を選択します。 .
繰り返しパネルをクリックし、パネルを繰り返し可能にするのスイッチをオンにします。
最小繰り返し可能セクションの必要に応じて最小繰り返し回数を設定します。パネルを繰り返しない場合、または繰り返しパネルを削除するには、最小繰り返し回数を 0 に設定できます。デフォルトでは、最小繰り返し回数の値は 0 です。
最大繰り返し回数を設定して、必要な回数パネルを繰り返します。デフォルトの値は無限です。
パネルの親要素に繰り返しを許可する場合は、パネルの繰り返しインスタンスを管理するために追加ボタンが含まれている必要があります。親要素にボタンを挿入し、ボタン上のスクリプトを有効にするには、以下の手順を実行します。
ボタンコンポーネントをパネルの親要素に追加します。以下のビデオの例では、ラベル名 Add とフィールド名 AddPanel のボタンコンポーネントが使用されています。コンポーネントを選択し、「 」を選択します。 . ルールエディターでボタンコンポーネントのルールが開きます。
ルールエディターウィンドウで、「作成」をクリックします。
フォームオブジェクトと関数の行で、「ビジュアルエディター」を選択します。
フォームオブジェクトと関数の行で、「コードエディター」を選択します。「ルールを編集」をクリックして、コード領域で以下の操作を行います。
this.panel.instanceManager.addInstance()
を指定します。「完了」をクリックします。
パネルの親要素には、繰り返し可能なパネルのインスタンスを削除するために削除ボタンが含まれている必要があります。親要素にボタンを挿入し、ボタン上のスクリプトを有効にして反復可能なパネルを削除するには、以下の手順を実行します。
ボタンコンポーネントをパネルの親要素に追加します。下のビデオでは、ラベル名 DELETE が付いたボタンコンポーネントおよびフィールド名 DeletePanel が使用されます。コンポーネントを選択し、「 」を選択します。 . ルールエディターでボタンコンポーネントのルールが開きます。
ルールエディターウィンドウで、「作成」をクリックします。
フォームオブジェクトと関数の行で、「ビジュアルエディター」を選択します。
フォームオブジェクトと関数の行で、「コードエディター」を選択します。「ルールを編集」をクリックして、コード領域で以下の操作を行います。
this.panel.instanceManager.removeInstance(this.panel.instanceIndex)
を指定します。「完了」をクリックします。
フィールドが繰り返し可能なパネルに属する場合、スクリプトで名前を指定して直接アクセスすることはできません。フィールドにアクセスするには、instances
の InstanceManager
API を使用してフィールドが属している繰り返し可能インスタンスを指定します。instances
の API InstanceManager
を使用するための構文を以下に示します。
<panelName>.instanceManager.instances[<instanceNumber>].<fieldname>
例えば、テキストボックスを持つ繰り返し可能なパネルを含むアダプティブフォームを作成するとします。このフォームに 3 つの繰り返し可能テキストボックスを事前入力するには、以下の xml が必要です。
<panel1><textbox1>AA1</panel1></textbox1>
<panel1><textbox1>AA2</panel1></textbox1>
<panel1><textbox1>AA3</panel1></textbox1>
AA1 データを読み込むには、以下のように指定します。
Panel1.instanceManager.instances[0].textbox.value
AA2 データを読み込むには、以下のように指定します。
Panel1.instanceManager.instances[1].textbox.value
パネルのすべてのインスタンスがアダプティブフォームから削除された場合、削除されたパネルのインスタンスを追加するには、 _panelName 構文を使用してパネルのインスタンスマネージャーを取り込み、削除されたインスタンスを追加するには、 addInstance API を使用します。 例えば、_panelName.addInstance() です。削除されたパネルのインスタンスを 1 つ追加します。
繰り返し可能なサブフォームは、アダプティブフォームの繰り返し可能なパネルに似ています。AEM Forms Designer で繰り返しのサブフォームを作成するには、以下の手順を実行します。
添付の .zip ファイルには、繰り返し可能なサブフォーラムのサンプルが含まれています。
XML スキーマ、または任意の複合タイプ要素の minOccurs および maxOccurs プロパティから、繰り返し可能なパネルを作成できます。XML スキーマについて詳しくは、XML スキーマをフォームモデルとして使用するアダプティブフォームを作成を参照してください。
以下のコードでは、SampleType
パネルで minOccurs および maxOccurs プロパティが使用されています。
<?xml version="1.0" encoding="utf-8" ?>
<xs:schema targetNamespace="https://adobe.com/sample.xsd"
xmlns="https://adobe.com/sample.xsd"
xmlns:xs="https://www.w3.org/2001/XMLSchema"
>
<xs:element name="sample" type="SampleType"/>
<xs:complexType name="SampleType">
<xs:sequence>
<xs:element name="leaderName" type="xs:string" default="Enter Name"/>
<xs:element name="assignmentStartDate" type="xs:date"/>
<xs:element name="gender" type="GenderEnum"/>
<xs:element name="noOfProjectsAssigned" type="IntType"/>
<xs:element name="assignmentDetails" type="AssignmentDetails"
minOccurs="0" maxOccurs="10"/>
</xs:sequence>
</xs:complexType>
<xs:complexType name="AssignmentDetails">
<xs:attribute name="name" type="xs:string" use="required"/>
<xs:attribute name="durationOfAssignment" type="xs:unsignedInt" use="required"/>
<xs:attribute name="numberOfMentees" type="xs:unsignedInt" use="required"/>
<xs:attribute name="descriptionOfAssignment" type="xs:string" use="required"/>
<xs:attribute name="financeRelatedProject" type="xs:boolean"/>
</xs:complexType>
<xs:simpleType name="IntType">
<xs:restriction base="xs:int">
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="GenderEnum">
<xs:restriction base="xs:string">
<xs:enumeration value="Female"/>
<xs:enumeration value="Male"/>
</xs:restriction>
</xs:simpleType>
</xs:schema>