Crear formularios adaptables mediante el esquema XML
- Se aplica a:
- Experience Manager 6.5
Creado para:
- Principiante
- Intermedio
- Usuario
- Desarrollador
Adobe recomienda utilizar la captura de datos moderna y ampliable Componentes principales para crear un nuevo formulario adaptable o añadir formularios adaptables a páginas de AEM Sites. Estos componentes representan un avance significativo en la creación de formularios adaptables, lo que garantiza experiencias de usuario impresionantes. Este artículo describe un enfoque más antiguo para crear Formularios adaptables con componentes de base.
Requisitos previos
La creación de un formulario adaptable con un esquema XML como modelo de formulario requiere una comprensión básica de los esquemas XML. Además, se recomienda leer el siguiente contenido antes que este artículo.
Uso de un esquema XML como modelo de formulario
Experience Manager Forms admite la creación de un formulario adaptable mediante un esquema XML existente como modelo de formulario. Este esquema XML representa la estructura en la que el sistema back-end de su organización produce o consume datos.
Estas son las características clave del uso de un esquema XML:
- La estructura del XSD se muestra como un árbol en la pestaña Buscador de contenido en el modo de creación de un formulario adaptable. Puede arrastrar y agregar un elemento de la jerarquía XSD al formulario adaptable.
- Puede rellenar previamente el formulario utilizando XML que cumpla con el esquema asociado.
- Al realizar el envío, los datos introducidos por el usuario se envían como XML que se ajusta al esquema asociado.
Un esquema XML consta de tipos de elementos simples y complejos. Los elementos tienen atributos que agregan reglas al elemento. Cuando estos elementos y atributos se arrastran a un formulario adaptable, se asignan automáticamente al componente del formulario adaptable correspondiente.
Esta asignación de elementos XML con componentes del formulario adaptable se produce de la siguiente forma:
xs:string
xs:boolean
xs:unsignedInt
xs:xs:int
xs:decimal
- Todos los tipos de valores numéricos
xs:date
xs:enumeration
Esquema XML de ejemplo
Este es un ejemplo de esquema XML.
<?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="assignmentStartBirth" 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>
Adición de propiedades especiales a campos mediante un esquema XML
Puede agregar los siguientes atributos a los elementos de esquema XML para agregar propiedades especiales a los campos del formulario adaptable asociado.
use=required
default="default value"
minOccurs="3"
Especifica ocurrencias mínimas
(Para subformularios repetibles (tipos complejos))
maxOccurs="10"
Especifica el número máximo de ocurrencias
(Para subformularios repetibles (tipos complejos))
- al poner en mayúscula el primer carácter del nombre del elemento;
- al insertar un espacio en blanco en los límites de Camel Case.
userFirstName
, la descripción generada en el formulario adaptable es User First Name
.Limitar los valores aceptables para un componente de formulario adaptable
Puede agregar las siguientes restricciones a los elementos de esquema XML para limitar los valores aceptables para un componente de formulario adaptable:
totalDigits
- Cuadro numérico
- Stepper numérico
maximum
- Cuadro numérico
- Stepper numérico
- Selector de fecha
minimum
- Cuadro numérico
- Stepper numérico
- Selector de fecha
exclusiveMaximum
Si es true, el valor numérico o la fecha especificados en el componente del formulario deben ser menores que el valor numérico o la fecha especificados para la propiedad máxima.
Si es false, el valor numérico o la fecha especificados en el componente del formulario deben ser menores o iguales al valor numérico o a la fecha especificados para la propiedad máxima.
- Cuadro numérico
- Stepper numérico
- Selector de fecha
exclusiveMinimum
Si es true, el valor numérico o la fecha especificados en el componente del formulario deben ser mayores que el valor numérico o la fecha especificados para la propiedad mínima.
Si es false, el valor numérico o la fecha especificados en el componente del formulario deben ser mayores o iguales al valor numérico o la fecha especificados para la propiedad mínima.
- Cuadro numérico
- Stepper numérico
- Selector de fecha
minLength
- Cuadro de texto
maxLength
- Cuadro de texto
length
- Cuadro de texto
fractionDigits
- Cuadro numérico con tipo de datos flotante o decimal
pattern
Especifica la secuencia de caracteres. Un componente acepta los caracteres si se ajustan al patrón especificado.
La propiedad pattern se asigna al patrón de validación del componente de formulario adaptable correspondiente.
- Todos los componentes de formulario adaptable asignados a un esquema XSD
Preguntas frecuentes
¿Cómo sé qué elemento del árbol está asociado con qué elemento XML?
Al hacer doble clic en un elemento del Buscador de contenido, una ventana emergente mostrará un nombre de campo y una propiedad llamada bindRef
. Esta propiedad asigna el elemento de árbol al elemento o atributo del esquema.
El bindRef
Este campo muestra la asociación entre un elemento de árbol y un elemento o atributo de un esquema.
@
en su valor bindRef
para distinguirlos de los elementos. Por ejemplo, /config/projectDetails/@duration
.¿Por qué no puedo arrastrar elementos individuales de un subformulario (estructura generada a partir de cualquier tipo complejo) para subformularios repetibles (los valores minOccours o maxOccurs son superiores a 1)?
En un subformulario repetible, debe utilizar el subformulario Completo. Si solo le interesan los campos selectivos, utilice toda la estructura y elimine los no deseados.
Tengo una estructura larga y compleja en el Buscador de contenido. ¿Cómo puedo encontrar un elemento específico?
Tiene dos opciones:
- Desplazarse por la estructura de árbol
- Utilizar el cuadro Buscar para buscar un elemento
¿Qué es bindRef?
Un bindRef
es la conexión entre un componente de formulario adaptable y un elemento o atributo de esquema. Determina en qué XPath
está disponible el valor capturado de este componente o campo en el XML de salida. bindRef
también se utiliza cuando se rellena previamente un valor de campo de un XML prerellenado (rellenado previamente).