Saltar al contenido principal

ComboBox

Abrir en ChatGPT
Shadow dwc-combobox 23.05
Java API
Inheritance

This class is a List component, and inherits its features and behaviors. For an overview of List properties, events, and other important information, please refer to the List documentation.

El componente ComboBox es un elemento de interfaz de usuario diseñado para presentar a los usuarios una lista de opciones o elecciones, así como un campo para ingresar sus propios valores personalizados. Los usuarios pueden seleccionar una única opción de esta lista, normalmente haciendo clic en el ComboBox, lo que desencadena la visualización de una lista desplegable que contiene las opciones disponibles, o escribir un valor personalizado. Los usuarios también pueden interactuar con el ComboBox usando las teclas de flecha. Cuando un usuario hace una selección, la opción elegida se muestra en el ComboBox.

Usos

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:

  1. Búsqueda y entrada de productos: Utilice 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 un nombre de producto personalizado. Esto es útil para aplicaciones como sitios de comercio electrónico donde los productos son numerosos y diversos.

  2. Selección y entrada de etiquetas: En aplicaciones que involucran la 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.
  3. Entrada de datos con valores sugeridos: En formularios de entrada de datos, un ComboBox se puede usar para acelerar la entrada proporcionando una lista de valores sugeridos según la entrada del usuario. Esto ayuda a los usuarios a ingresar datos de manera precisa y eficiente.

    sugerencia

    El ComboBox debe usarse cuando se permite a los usuarios ingresar valores personalizados. Si solo se desean valores preestablecidos, use un ChoiceBox en su lugar.

Valor personalizado

Cambiar la propiedad del valor personalizado permite controlar si el usuario puede o no cambiar el valor en el campo de entrada del componente ComboBox. Si se establece en true, que es el valor predeterminado, entonces un usuario puede cambiar el valor. Si se establece en false, el usuario no podrá cambiar el valor. Esto se puede configurar usando el método setAllowCustomValue().

Mostrar Código

Marcador de posición

Se puede configurar un marcador de posición para un ComboBox que se mostrará en el campo de texto del componente cuando esté vacío para solicitar a los usuarios la entrada deseada en el campo. Esto se puede hacer utilizando el método setPlaceholder().

Mostrar Código

Usar el método setDropdownType() 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 diseño, 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 al abrirse.

Este desgarro crea una situación en la que apuntar directamente al desplegable usando selectores CSS o de partes de sombra desde el componente principal se vuelve un desafío, a menos que se utilice el atributo de tipo de desplegable.

En la demostración a continuación, se establece y utiliza el tipo de desplegable en el archivo CSS para seleccionar el desplegable y cambiar el color de fondo.

Mostrar Código

Conteo máximo de filas

Por defecto, el número de filas mostradas en el desplegable de un ComboBox se aumentará para adaptarse al contenido. Sin embargo, usar el método setMaxRowCount() permite controlar cuántos elementos se muestran.

precaución

Usar un número que sea menor o igual a 0 resultará en desactivar esta propiedad.

Mostrar Código

Apertura y cierre

La visibilidad de las opciones de un ComboBox se puede controlar programáticamente con los métodos open() y close(). Estos métodos permiten mostrar la lista de opciones para la selección o esconderla según sea necesario, proporcionando mayor flexibilidad en la gestión del comportamiento de un ComboBox.

Además, webforJ tiene oyentes 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 carrera = new ComboBox("Carrera");
Button enviar = new Button("Enviar");

//... Agregar listas de universidades y carreras

universidad.onClose( e ->{
carrera.open();
});

carrera.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 los métodos setOpenHeight() y setOpenWidth(), respectivamente.

sugerencia

Pasar un valor String a cualquiera de estos métodos permitirá aplicar cualquier unidad CSS válida, como píxeles, dimensiones de visualización 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 el foco. Esta función puede reducir errores de entrada cuando los usuarios están completando formularios y puede mejorar la experiencia general de navegación. Cambia el comportamiento de resaltado usando el método setHighlightOnFocus() con uno de los enums incorporados HasHighlightOnFocus.Behavior:

  • ALL Los contenidos del componente siempre se resaltan automáticamente cuando el componente recibe foco.
  • FOCUS Los contenidos del componente se resaltan automáticamente cuando el componente recibe foco bajo control del programa.
  • FOCUS_OR_KEY Los contenidos del componente se resaltan automáticamente cuando el componente recibe foco bajo control del programa o al tabular hacia él.
  • FOCUS_OR_MOUSE Los contenidos del componente se resaltan automáticamente cuando el componente recibe foco bajo control del programa o al hacer clic en él con el mouse.
  • KEY Los contenidos del componente se resaltan automáticamente cuando el componente recibe foco al tabular hacia él.
  • KEY_MOUSE Los contenidos del componente se resaltan automáticamente cuando el componente recibe foco al tabular hacia él o al hacer clic en él con el mouse.
  • MOUSE Los contenidos del componente se resaltan automáticamente cuando el componente recibe foco al hacer clic en él con el mouse.
  • NONE Los contenidos del componente nunca se resaltan automáticamente cuando el componente obtiene foco.
nota

Si el contenido estuvo resaltado al perder el foco, se resaltará nuevamente al recuperar 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, imágenes de avatar/perfil y otros componentes beneficiosos anidados dentro de un ComboBox para clarificar el significado intentado a los usuarios. El ComboBox tiene dos slots: el slot prefix y el slot suffix. 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"));

Estilización

Loading...

Mejores prácticas

Para garantizar una experiencia óptima del usuario al utilizar el componente ComboBox, considera las siguientes mejores prácticas:

  1. Precargar valores comunes: Si hay elementos comunes o utilizados con frecuencia, precárgalos en la lista del ComboBox. Esto acelera la selección de elementos comúnmente elegidos y fomenta la consistencia.

  2. 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.

  3. Validación: Implementa validación de entrada para manejar entradas personalizadas. Verifica la precisión y consistencia de los datos. Puede que desees sugerir correcciones o confirmaciones para entradas ambiguas.

  4. Selección por defecto: Establece una selección por defecto, especialmente si hay una opción común o recomendada. Esto mejora la experiencia del usuario al reducir la necesidad de clics adicionales.

  5. ComboBox versus otros componentes de lista: Un ComboBox es 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:

    • Selección múltiple y mostrar todos los elementos a la vez: ListBox
    • Prevenir entrada personalizada: ChoiceBox