AEM 6.4 ha raggiunto la fine del supporto esteso e questa documentazione non viene più aggiornata. Per maggiori dettagli, consulta la nostra periodi di assistenza tecnica. Trova le versioni supportate qui.
Le sezioni ripetibili sono pannelli che possono essere aggiunti o rimossi in modo dinamico da un modulo.
Ad esempio, quando si richiede un lavoro, il ricercatore di lavoro fornisce i dettagli precedenti sull'occupazione, come il nome dell'azienda, il ruolo, il progetto e altre informazioni. L'informazione di tutti i datori di lavoro richiede sezioni diverse ma simili. In questo caso, il modulo per l'occupazione fornisce una sezione datore di lavoro e fornisce anche un'opzione per aggiungere in modo dinamico altre sezioni di questo tipo. Queste sezioni, aggiunte in modo dinamico, sono note come sezioni ripetibili.
Per creare pannelli ripetibili è possibile utilizzare uno dei metodi seguenti:
In modalità di modifica, seleziona un pannello, quindi tocca . Nella barra laterale, in Proprietà, abilita Rendi pannello ripetibile. Specifica i valori per Massimo e Minimo campi.
Il campo Massimo specifica il numero massimo di volte in cui un pannello può essere visualizzato sulla pagina. Puoi specificare -1 nel campo Conteggio massimo per consentire la visualizzazione del pannello per un numero infinito di volte.
Il campo Minimo specifica il numero minimo di volte in cui un pannello viene visualizzato sul modulo. Se in seguito si imposta il campo Conteggio minimo su zero, è possibile rimuovere tutte le istanze tramite script al termine del rendering.
Per creare un pannello non ripetibile, impostare su uno il valore del campo Massimo e Minimo. Il layout a soffietto non supporta -1 nel campo Conteggio massimo . Puoi specificare un numero elevato per definire il concetto di valore infinito.
L’elemento padre del pannello, che deve essere ripetuto, deve contenere pulsanti di aggiunta ed eliminazione per gestire le istanze dei pannelli ripetibili. Effettuare le seguenti operazioni per inserire i pulsanti nell'elemento padre e abilitare gli script nei pulsanti:
Dalla barra laterale, trascinate un componente pulsante nell’elemento padre del pannello. Seleziona il componente e tocca . Le regole del pulsante si aprono nell’editor di regole.
Nella finestra Editor regole, fai clic su Crea.
Seleziona Editor visivo nella riga Oggetti modulo e funzioni.
Nell'area della regola, in QUANDO, selezionare stato è selezionato.
Sotto THEN:
Seleziona Editor di codice nella riga Oggetti modulo e funzioni. Fai clic su Modifica regole e nell'area codice:
this.panel.instanceManager.addInstance()
this.panel.instanceManager.removeInstance(this.panel.instanceIndex)
Fai clic su Fine.
Se un campo appartiene a un pannello ripetibile, non è possibile accedervi direttamente utilizzando il suo nome negli script. Per accedere al campo, specifica l’istanza ripetibile a cui appartiene il campo utilizzando la instances
API in InstanceManager
. La sintassi da utilizzare instances
API in InstanceManager
è:
<panelName>.instanceManager.instances[<instanceNumber>].<fieldname>
Ad esempio, è possibile creare un modulo adattivo con un pannello ripetibile con una casella di testo. Quando si precompila il modulo con tre caselle di testo ripetibili, è necessario utilizzare il codice xml sottostante:
<panel1><textbox1>AA1</panel1></textbox1>
<panel1><textbox1>AA2</panel1></textbox1>
<panel1><textbox1>AA3</panel1></textbox1>
Per leggere i dati AA1, specifica:
Panel1.instanceManager.instances[0].textbox.value
Per leggere i dati AA2, specifica:
Panel1.instanceManager.instances[1].textbox.value
Per ulteriori informazioni, consulta: Classe: InstanceManager#instances in Riferimento API Java di AEM Forms.
Quando tutte le istanze di un pannello vengono rimosse da un modulo adattivo, per aggiungere un’istanza del pannello rimosso, utilizza la sintassi _panelName per acquisire il gestore di istanze del pannello e l’API addInstance di instance manager per aggiungere l’istanza eliminata. Ad esempio, _panelName.addInstance(). Aggiunge un'istanza del pannello rimosso.
Un pannello dispone di diverse opzioni di layout. L'opzione Layout per il design accordiano è preconfigurata per pannelli ripetibili. Esegui i seguenti passaggi per il pannello ripetibile con l'opzione Layout per la progettazione accordian:
Nell’elemento padre del pannello da ripetere, tocca . Puoi vedere le proprietà nella barra laterale. In Layout a discesa, seleziona Accordion.
Tocca su un pannello da ripetere . Puoi visualizzare le proprietà del pannello nella barra laterale. Abilita la Rendi pannello ripetibile e specifica il valore per Massimo e Minimo campi.
Ora è possibile utilizzare il segno più (+) ed eliminare ( ) per aggiungere e rimuovere i pannelli.
Il sottomodulo ripetibile è simile ai pannelli ripetibili in Forms adattivo. In AEM Forms Designer, eseguire i seguenti passaggi per creare un sottomodulo ripetuto:
Il file .zip allegato contiene un sottomodulo ripetibile di esempio.
È possibile creare pannelli ripetibili da uno schema XML e dalla proprietà minOccours & maxOccours di qualsiasi elemento di tipo complesso. Per informazioni dettagliate sullo schema XML, vedere Creare moduli adattivi utilizzando lo schema XML come modello di modulo.
Nel codice seguente, la SampleType
Il pannello utilizza la proprietà minOccours e 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>
Per il layout non generico, utilizza i componenti pulsante per moduli adattivi per aggiungere e rimuovere istanze.