Saltar al contenido principal

TabbedPane

Abrir en ChatGPT
Shadow dwc-tabbed-pane 23.06
Java API

La clase TabbedPane proporciona una manera compacta y organizada de mostrar contenido que está dividido en múltiples secciones, cada una asociada con una Tab. Los usuarios pueden cambiar entre estas secciones haciendo clic en las pestañas respectivas, que a menudo están etiquetadas con texto y/o íconos. Esta clase simplifica la creación de interfaces multifacéticas donde diferentes contenidos o formularios necesitan ser accesibles, pero no visibles simultáneamente.

Usos

La clase TabbedPane ofrece a los desarrolladores una herramienta poderosa para organizar y presentar múltiples pestañas o secciones dentro de una interfaz de usuario. Aquí hay algunos escenarios típicos donde podrías utilizar un TabbedPane en tu aplicación:

  1. Visor de Documentos: Implementar un visor de documentos donde cada pestaña representa un diferente documento o archivo. Los usuarios pueden cambiar fácilmente entre los documentos abiertos para un multitasking eficiente.

  2. Gestión de Datos: Utilizar un TabbedPane para organizar tareas de gestión de datos, por ejemplo:

    • Diferentes conjuntos de datos que se mostrarán en una aplicación
    • Varios perfiles de usuario pueden ser mostrados dentro de pestañas separadas
    • Diferentes perfiles en un sistema de gestión de usuarios
  3. Selección de Módulo: Un TabbedPane puede representar diferentes módulos o secciones. Cada pestaña puede encapsular las funcionalidades de un módulo específico, permitiendo a los usuarios enfocarse en un aspecto de la aplicación a la vez.

  4. Gestión de Tareas: Las aplicaciones de gestión de tareas pueden usar un TabbedPane para representar varios proyectos o tareas. Cada pestaña podría corresponder a un proyecto específico, permitiendo a los usuarios gestionar y rastrear tareas por separado.

  5. Navegación de Programas: Dentro de una aplicación que necesita ejecutar varios programas, un TabbedPane podría:

    • Servir como una barra lateral que permite ejecutar diferentes aplicaciones o programas dentro de una única aplicación, como se muestra en la plantilla AppLayout
    • Crear una barra superior que puede servir un propósito similar, o representar sub-aplicaciones dentro de una aplicación ya seleccionada.

Pestañas

Las pestañas son elementos de interfaz de usuario que se pueden agregar a los paneles de pestañas para organizar y cambiar entre diferentes vistas de contenido.

important

Las pestañas no están destinadas a ser utilizadas como componentes independientes. Deben ser utilizadas en conjunto con paneles de pestañas. Esta clase no es un Component y no debe ser utilizada como tal.

Propiedades

Las pestañas están compuestas por las siguientes propiedades, que se utilizan al agregarlas en un TabbedPane. Estas propiedades tienen métodos de acceso y de modificación para facilitar la personalización dentro de un TabbedPane.

  1. Key(Object): Representa el identificador único para la Tab.

  2. Texto(String): El texto que se mostrará como título para la Tab dentro del TabbedPane. Esto también se conoce como el título a través de los métodos getTitle() y setTitle(String title).

  3. Tooltip(String): El texto de ayuda que está asociado con la Tab, que se mostrará cuando el cursor pase sobre la Tab.

  4. Enabled(boolean): Representa si la Tab está actualmente habilitada o no. Se puede modificar con el método setEnabled(boolean enabled).

  5. Closeable(boolean): Representa si la Tab puede ser cerrada. Se puede modificar con el método setCloseable(boolean enabled). Esto agregará un botón de cierre en la Tab que puede ser clicado por el usuario, y desencadena un evento de eliminación. El componente TabbedPane dicta cómo manejar la eliminación.

  6. Slot(Component): Los slots proporcionan opciones flexibles para mejorar la capacidad de una Tab. Puedes tener íconos, etiquetas, spinners de carga, capacidades de limpiar/restablecer, fotos de perfil/avatar, y otros componentes beneficiosos anidados dentro de una Tab para aclarar aún más el significado intencionado a los usuarios. Puedes agregar un componente al slot prefix de una Tab durante su construcción. Alternativamente, puedes usar los métodos setPrefixComponent() y setSuffixComponent() para insertar varios componentes antes y después de la opción mostrada dentro de una Tab.

    TabbedPane pane = new TabbedPane();
    pane.addTab(new Tab("Documents", TablerIcon.create("files")));

Manipulación de Tab

Existen varios métodos que permiten a los desarrolladores agregar, insertar, eliminar y manipular varias propiedades de elementos Tab dentro del TabbedPane.

Agregar una Tab

Los métodos addTab() y add() existen en diferentes capacidades sobrecargadas para permitir a los desarrolladores flexibilidad al agregar nuevas pestañas al TabbedPane. Agregar una Tab la colocará después de cualquier pestaña existente anteriormente.

  1. addTab(String text) - Agrega una Tab al TabbedPane con el String especificado como el texto de la Tab.
  2. addTab(Tab tab) - Agrega la Tab proporcionada como parámetro al TabbedPane.
  3. addTab(String text, Component component) - Agrega una Tab con el String dado como texto de la Tab, y el Component proporcionado mostrado en la sección de contenido del TabbedPane.
  4. addTab(Tab tab, Component component) - Agrega la Tab proporcionada y muestra el Component proporcionado en la sección de contenido del TabbedPane.
  5. add(Component... component) - Agrega una o más instancias de Component al TabbedPane, creando una Tab discreta para cada una, con el texto establecido en el nombre del Component.
info

El add(Component... component) determina el nombre del Component pasado llamando a component.getName() en el argumento pasado.

Insertar una Tab

Además de agregar una Tab al final de las pestañas existentes, también es posible crear una nueva en una posición designada. Para hacer esto, se utilizan múltiples versiones sobrecargadas del insertTab().

  1. insertTab(int index, String text) - Inserta una Tab en el TabbedPane en el índice dado con el String especificado como el texto de la Tab.
  2. insertTab(int index, Tab tab) - Inserta la Tab proporcionada como parámetro al TabbedPane en el índice especificado.
  3. insertTab(int index, String text, Component component) - Inserta una Tab con el String dado como el texto de la Tab, y el Component proporcionado mostrado en la sección de contenido del TabbedPane.
  4. insertTab(int index, Tab tab, Component component) - Inserta la Tab proporcionada y muestra el Component proporcionado en la sección de contenido del TabbedPane.

Eliminar una Tab

Para eliminar una única Tab del TabbedPane, utiliza uno de los siguientes métodos:

  1. removeTab(Tab tab) - Elimina una Tab del TabbedPane pasando la instancia de Tab a eliminar.
  2. removeTab(int index) - Elimina una Tab del TabbedPane especificando el índice de la Tab a eliminar.

Además de los dos métodos anteriores para la eliminación de una única Tab, utiliza el método removeAllTabs() para limpiar el TabbedPane de todas las pestañas.

info

Los métodos remove() y removeAll() no eliminan pestañas dentro del componente.

Asociación Tab/Componente

Para cambiar el Component que se mostrará para una Tab determinada, llama al método setComponentFor() y pasa ya sea la instancia de la Tab, o el índice de esa Tab dentro del TabbedPane.

info

Si este método se usa en una Tab que ya está asociada con un Component, el Component previamente asociado será destruido.

Configuración y diseño

La clase TabbedPane tiene dos partes constituyentes: una Tab que se muestra en una ubicación específica, y un componente que se mostrará. Esto puede ser un único componente, o un componente Composite, permitiendo la visualización de componentes más complejos dentro de la sección de contenido de una pestaña.

Deslizamiento

El TabbedPane admite la navegación a través de las diversas pestañas mediante deslizamiento. Esto es ideal para una aplicación móvil, pero también puede ser configurado mediante un método incorporado para admitir el deslizamiento con el mouse. Tanto el deslizamiento como el deslizamiento con el mouse están deshabilitados por defecto, pero pueden ser habilitados con los métodos setSwipable(boolean) y setSwipableWithMouse(boolean), respectivamente.

Colocación de Pestañas

Las Tabs dentro de un TabbedPane pueden colocarse en varias posiciones dentro del componente según la preferencia del desarrollador de la aplicación. Las opciones proporcionadas se establecen utilizando la enumeración proporcionada, que tiene los valores de TOP, BOTTOM, LEFT, RIGHT, o HIDDEN. La configuración predeterminada es TOP.

Mostrar Código

Alineación

Además de cambiar la colocación de los elementos Tab dentro del TabbedPane, también es posible configurar cómo se alinearán las pestañas dentro del componente. Por defecto, la configuración AUTO está en efecto, lo que permite que la colocación de las pestañas dicte su alineación.

Las otras opciones son START, END, CENTER, y STRETCH. Las tres primeras describen la posición en relación con el componente, mientras que STRETCH hace que las pestañas llenen el espacio disponible.

Mostrar Código

Borde e indicador de actividad

El TabbedPane tendrá un borde mostrado para las pestañas dentro de él por defecto, colocado dependiendo de qué Placement se haya establecido. Este borde ayuda a visualizar el espacio que ocupan las diversas pestañas dentro del panel.

Cuando se hace clic en una Tab, por defecto, se muestra un indicador de actividad cerca de esa Tab para ayudar a resaltar cuál es la Tab actualmente seleccionada.

Ambas opciones pueden ser personalizadas por un desarrollador mediante el cambio de los valores booleanos utilizando los métodos setters apropiados. Para cambiar si el borde se muestra o no, se puede usar el método setBorderless(boolean), con true ocultando el borde, y false, el valor predeterminado, mostrando el borde.

info

Este borde no se aplica a la totalidad del componente TabbedPane, y solo sirve como un separador entre las pestañas y el contenido del componente.

Para establecer la visibilidad del indicador activo, se puede usar el método setHideActiveIndicator(boolean). Pasar true a este método ocultará el indicador activo debajo de una Tab activa, mientras que false, el valor predeterminado, mantendrá el indicador visible.

Mostrar Código

Modos de activación

Para un control más fino sobre cómo se comporta el TabbedPane cuando se navega mediante el teclado, se puede establecer el modo de Activation para especificar cómo debe comportarse el componente.

  • Auto: Cuando se establece en automático, navegar por las pestañas con las teclas de flecha mostrará instantáneamente el componente de pestaña correspondiente.

  • Manual: Cuando se establece en manual, la pestaña recibirá el foco, pero no se mostrará hasta que el usuario presione espacio o enter.

Mostrar Código

Opciones de eliminación

Los elementos de Tab individuales pueden establecerse como cerrables. Las pestañas cerrables tendrán un botón de cierre añadido a la pestaña, lo que desencadena un evento de cierre cuando se hace clic. El TabbedPane dicta cómo se maneja este comportamiento.

  • Manual: Por defecto, la eliminación se establece en MANUAL, lo que significa que se desencadena el evento, pero depende del desarrollador manejar este evento de la manera que elija.

  • Auto: Alternativamente, se puede usar AUTO, que desencadenará el evento y también eliminará la Tab del componente para el desarrollador, eliminando la necesidad de que el desarrollador implemente este comportamiento manualmente.

Estilo

Expansión y tema

El TabbedPane viene con opciones integradas de Expanse y Tema similares a otros componentes de webforJ. Estas se pueden utilizar para agregar rápidamente estilo que transmite varios significados al usuario final sin necesidad de estilizar el componente con CSS.

Mostrar Código

Loading...

Mejores prácticas

Se recomiendan las siguientes prácticas para utilizar el TabbedPane dentro de las aplicaciones:

  • Agrupamiento Lógico: Usa pestañas para agrupar lógicamente contenido relacionado.

    • Cada pestaña debe representar una categoría o funcionalidad distinta dentro de tu aplicación.
    • Agrupa pestañas similares o lógicas cerca unas de otras.
  • Pocas Pestañas: Evita abrumar a los usuarios con demasiadas pestañas. Considera usar una estructura jerárquica u otros patrones de navegación donde sea aplicable para una interfaz limpia.

  • Etiquetas Claras: Etiqueta claramente tus Pestañas para un uso intuitivo.

    • Proporciona etiquetas claras y concisas para cada pestaña.
    • Las etiquetas deben reflejar el contenido o propósito, haciendo fácil para los usuarios entender.
    • Utiliza íconos y colores distintos donde sea aplicable.
  • Navegación con Teclado: Usa el soporte de navegación por teclado de TabbedPane de webforJ para hacer la interacción con el TabbedPane más fluida e intuitiva para el usuario final.

  • Pestaña por Defecto: Si la pestaña por defecto no está colocada al principio del TabbedPane, considera establecer esta pestaña como la predeterminada para información esencial o de uso común.