ComboBox
El componente ComboBox combina una lista desplegable con una entrada de texto, de modo que los usuarios pueden seleccionar entre opciones predefinidas o escribir un valor personalizado. Cuando es necesario permitir entradas personalizadas junto a un conjunto de opciones sugeridas, llena el vacío que ChoiceBox no cubre.
Usos
This class is a Lista component, and inherits its features and behaviors. For an overview of Lista properties, events, and other important information, please refer to the Lista documentation.
El componente ComboBox es un elemento de entrada versátil que combina las características de una lista desplegable y un campo de entrada de texto. Permite a los usuarios seleccionar elementos de una lista predefinida o ingresar valores personalizados según sea necesario. Esta sección explora los usos comunes del componente ComboBox en varios escenarios:
-
Búsqueda y entrada de productos: Usa un ComboBox para implementar una función de búsqueda y entrada de productos. Los usuarios pueden seleccionar un producto de una lista predefinida o escribir el nombre de un producto personalizado. Esto es útil para aplicaciones como sitios de comercio electrónico donde los productos son vastos y diversos.
-
Selección y entrada de etiquetas: En aplicaciones que implican etiquetado de contenido, un ComboBox puede ser una excelente opción. Los usuarios pueden seleccionar de una lista de etiquetas existentes o agregar etiquetas personalizadas escribiéndolas. Esto es útil para organizar y categorizar contenido. Ejemplos de tales etiquetas incluyen:
- Etiquetas de proyecto: En una herramienta de gestión de proyectos, los usuarios pueden seleccionar etiquetas o tags (por ejemplo, "Urgente", "En Progreso", "Completado") para categorizar tareas o proyectos, y pueden crear etiquetas personalizadas según sea necesario.
- Ingredientes de recetas: En una aplicación de cocina o recetas, los usuarios pueden seleccionar ingredientes de una lista (por ejemplo, "Tomates", "Cebollas", "Pollo") o agregar sus propios ingredientes para recetas personalizadas.
- Etiquetas de ubicación: En una aplicación de mapeo o geolocalización, los usuarios pueden elegir etiquetas de ubicación predefinidas (por ejemplo, "Playa", "Ciudad", "Parque") o crear etiquetas personalizadas para marcar lugares específicos en un mapa.
-
Entrada de datos con valores sugeridos: En formularios de entrada de datos, un ComboBox se puede usar para acelerar la entrada al proporcionar una lista de valores sugeridos basada en la entrada del usuario. Esto ayuda a los usuarios a ingresar datos de manera precisa y eficiente.
sugerenciaEl
ComboBoxdebe usarse cuando se permite a los usuarios ingresar valores personalizados. Si solo se desean valores preestablecidos, usa unChoiceBoxen su lugar.
Valor personalizado
Cambiar la propiedad de valor personalizado permite controlar si un usuario puede o no cambiar el valor en el campo de entrada del componente ComboBox. Si es true, que es el valor predeterminado, un usuario puede cambiar el valor. Si se establece en false, el usuario no podrá cambiar el valor. Esto se puede establecer utilizando el setAllowCustomValue() método.
Mostrar Código
- ComboBoxCustomValueView.java
Placeholder
Se puede establecer un placeholder para un ComboBox, que se mostrará en el campo de texto del componente cuando esté vacío para indicar a los usuarios la entrada deseada en el campo. Esto se puede hacer utilizando el setPlaceholder() método.
Mostrar Código
- ComboBoxPlaceholderView.java
Tipo de desplegable
Usar el setDropdownType() método asignará un valor al atributo type de un ComboBox, y un valor correspondiente para el atributo data-dropdown-for en el desplegable del ComboBox. Esto es útil para el estilo, ya que el desplegable se saca de su posición actual en el DOM y se reubica al final del cuerpo de la página cuando se abre.
Este desenganche crea una situación en la que se vuelve complicado dirigir CSS o selectores de partes sombra desde el componente padre, a menos que se utilice el atributo tipo de desplegable.
En el demo a continuación, el tipo de desplegable se establece y se utiliza en el archivo CSS para aumentar el tamaño de una opción cuando pasas el mouse sobre ella.
Mostrar Código
- ComboBoxDropdownTypeView.java
- comboBoxDropDownType.css
Contador máximo de filas
Por defecto, el número de filas que se muestran en el desplegable de un ComboBox aumentará para ajustarse al contenido. Sin embargo, usar el setMaxRowCount() método permite controlar cuántos elementos se muestran.
Usar un número que sea menor o igual a 0 resultará en desconfigurar esta propiedad.
Mostrar Código
- ComboBoxMaxRowView.java
Abrir y cerrar
La visibilidad de las opciones para un ComboBox se puede controlar programáticamente con los métodos open() y close(). Estos métodos permiten mostrar la lista de opciones para selección o esconderla según sea necesario, proporcionando mayor flexibilidad en la gestión del comportamiento de un ComboBox.
Además, webforJ tiene escuchas de eventos para cuando el ComboBox se cierra y cuando se abre, dándote más control para activar acciones específicas.
//Enfocar o abrir el siguiente componente en un formulario
ComboBox universidad = new ComboBox("Universidad");
ComboBox especialidad = new ComboBox("Especialidad");
Button enviar = new Button("Enviar");
//... Agregar listas de universidades y especialidades
universidad.onClose( e ->{
especialidad.open();
});
especialidad.onClose( e ->{
enviar.focus();
});
Dimensiones de apertura
El componente ComboBox tiene métodos que permiten manipular las dimensiones del desplegable. La altura máxima y ancho mínimo del desplegable se pueden establecer utilizando el setOpenHeight() y setOpenWidth() métodos, respectivamente.
Pasar un valor String a cualquiera de estos métodos permitirá aplicar cualquier unidad CSS válida, como píxeles, dimensiones de viewport u otras reglas válidas. Pasar un int establecerá el valor pasado en píxeles.
Resaltado
Al trabajar con un ComboBox, puedes personalizar cuándo se resalta el texto según cómo el componente obtiene foco. Esta característica puede reducir errores de entrada cuando los usuarios completan formularios y puede mejorar la experiencia de navegación general. Cambia el comportamiento de resaltado usando el método setHighlightOnFocus() con uno de los enums HasHighlightOnFocus.Behavior incorporados:
ALLEl contenido del componente siempre se resalta automáticamente cuando el componente obtiene foco.FOCUSEl contenido del componente se resalta automáticamente cuando el componente obtiene foco bajo control del programa.FOCUS_OR_KEYEl contenido del componente se resalta automáticamente cuando el componente obtiene foco bajo control del programa o al tabular hacia él.FOCUS_OR_MOUSEEl contenido del componente se resalta automáticamente cuando el componente obtiene foco bajo control del programa o al hacer clic en él con el mouse.KEYEl contenido del componente se resalta automáticamente cuando el componente obtiene foco al tabular hacia él.KEY_MOUSEEl contenido del componente se resalta automáticamente cuando el componente obtiene foco al tabular hacia él o al hacer clic en él con el mouse.MOUSEEl contenido del componente se resalta automáticamente cuando el componente obtiene foco al hacer clic en él con el mouse.NONEEl contenido del componente nunca se resalta automáticamente cuando el componente obtiene foco.
Si el contenido fue resaltado al perder el foco, se resaltará nuevamente al volver a obtener el foco, independientemente del comportamiento establecido.
Prefijo y sufijo
Los slots proporcionan opciones flexibles para mejorar la capacidad de un ComboBox. Puedes tener íconos, etiquetas, spinners de carga, capacidad de limpiar/restablecer, fotos de avatar/perfil y otros componentes beneficiosos anidados dentro de un ComboBox para aclarar aún más el significado previsto a los usuarios.
El ComboBox tiene dos slots: los slots de prefijo y sufijo. Usa los métodos setPrefixComponent() y setSuffixComponent() para insertar varios componentes antes y después de las opciones dentro de un ComboBox.
ComboBox comboBox = new ComboBox());
comboBox.setPrefixComponent(TablerIcon.create("box"));
comboBox.setSuffixComponent(TablerIcon.create("box"));
Estilo
Mejores prácticas
Para garantizar una experiencia de usuario óptima al utilizar el componente ComboBox, considera las siguientes mejores prácticas:
-
Precargar valores comunes: Si hay elementos comunes o de uso frecuente, precárgalos en la lista del
ComboBox. Esto acelera la selección de elementos comúnmente elegidos y fomenta la consistencia. -
Etiquetas amigables para el usuario: Asegúrate de que las etiquetas mostradas para cada opción sean amigables para el usuario y autoexplicativas. Asegúrate de que los usuarios puedan comprender fácilmente el propósito de cada elección.
-
Validación: Implementa validación de entradas para manejar entradas personalizadas. Verifica la precisión y consistencia de los datos. Puede que quieras sugerir correcciones o confirmaciones para entradas ambiguas.
-
Selección predeterminada: Establece una selección predeterminada, especialmente si hay una opción común o recomendada. Esto mejora la experiencia del usuario al reducir la necesidad de clics adicionales.
-
ComboBox vs. Otros componentes de lista: Un
ComboBoxes la mejor opción si necesitas una única entrada del usuario y deseas proporcionarles opciones predeterminadas y la capacidad de personalizar su entrada. Otro componente de lista puede ser mejor si necesitas los siguientes comportamientos: