Saltar al contenido principal

AppLayout

Abrir en ChatGPT
Shadow dwc-app-layout 23.06
Java API

El AppLayout es un componente de diseño receptivo integral que proporciona un encabezado, un pie de página, un cajón y una sección de contenido. El encabezado y el pie de página son fijos, el cajón se desliza dentro y fuera del área de visualización, y el contenido es desplazable.

Este componente se puede utilizar para construir diseños de aplicaciones comunes, como un panel de control.

Características

El diseño de aplicación webforJ es un componente que permite construir diseños de aplicaciones comunes.

  • Fácil de usar y personalizar
  • Diseño receptivo
  • Múltiples opciones de diseño
  • Funciona con el Modo Oscuro de webforJ

Proporciona un encabezado, un pie de página, un cajón y una sección de contenido, todo integrado en un componente receptivo que se puede personalizar fácilmente para construir rápidamente diseños de aplicaciones comunes, como un panel de control. El encabezado y el pie de página son fijos, el cajón se desliza dentro y fuera del área de visualización, y el contenido es desplazable.

Cada parte del diseño es un Div, que puede contener cualquier control válido de webforJ. Para obtener los mejores resultados, la aplicación debe incluir una etiqueta meta de área de visualización que contenga viewport-fit=cover. La etiqueta meta hace que el área de visualización se escale para llenar la pantalla del dispositivo.

@AppMeta(name = "viewport", content = "width=device-width, initial-scale=1.0, viewport-fit=cover, user-scalable=no")

Descripción general

El siguiente ejemplo de código resultará en una aplicación con una barra lateral colapsable que contiene un logo y pestañas para varias opciones de contenido, además de un encabezado. La demostración utiliza el componente web dwc-icon-button para crear un botón de alternancia del cajón. El botón tiene el atributo data-drawer-toggle, que instruye al DwcAppLayout para escuchar los eventos de clic que provienen de ese componente para alternar el estado del cajón.

Mostrar Código

Barra de navegación de ancho completo

Por defecto, el AppLayout renderiza el encabezado y el pie de página en modo fuera de pantalla. El modo fuera de pantalla significa que la posición del encabezado y el pie de página se desplazará para ajustarse junto al cajón abierto. Desactivar este modo hará que el encabezado y el pie de página ocupen todo el espacio disponible y desplazará la posición superior e inferior del cajón para ajustarse con el encabezado y el pie de página.

AppLayout myApp = new AppLayout();

myApp.setHeaderOffscreen(false);
myApp.setFooterOffscreen(false);
Mostrar Código

Múltiples barras de herramientas

La barra de navegación no tiene límite en la cantidad de barras de herramientas que se pueden agregar. Una Toolbar es un componente contenedor horizontal que sostiene un conjunto de botones de acción, iconos u otros controles. Para agregar una barra de herramientas adicional, simplemente utiliza el método addToHeader() para agregar otro componente Toolbar.

La siguiente demostración muestra cómo usar dos barras de herramientas. La primera contiene el botón de alternancia del cajón y el título de la aplicación. La segunda barra de herramientas contiene un menú de navegación secundario.

Mostrar Código

Barras de herramientas pegajosas

Una barra de herramientas pegajosa es una barra de herramientas que permanece visible en la parte superior de la página cuando el usuario se desplaza hacia abajo, pero la altura de la barra de navegación se colapsa para dejar más espacio disponible para el contenido de la página. Normalmente, este tipo de barra de herramientas contiene un menú de navegación fijo que es relevante para la página actual.

Es posible crear barras de herramientas pegajosas utilizando la propiedad CSS personalizada --dwc-app-layout-header-collapse-height y la opción AppLayout.setHeaderReveal().

Cuando se establece AppLayout.setHeaderReveal(true), el encabezado será visible en la primera renderización y luego se ocultará cuando el usuario comience a desplazarse hacia abajo. Una vez que el usuario comience a desplazarse hacia arriba nuevamente, el encabezado se revelará.

Con la ayuda de la propiedad CSS personalizada --dwc-app-layout-header-collapse-height, es posible controlar cuánta parte de la barra de navegación del encabezado se ocultará.

Mostrar Código

Diseño de navegación móvil

La barra de navegación inferior se puede utilizar para proporcionar una versión diferente de la navegación en la parte inferior de la aplicación. Este tipo de navegación es específicamente popular en aplicaciones móviles.

Observa cómo el cajón está oculto en la siguiente demostración. El widget AppLayout admite tres posiciones de cajón: DrawerPlacement.LEFT, DrawerPlacement.RIGHT y DrawerPlacement.HIDDEN.

Al igual que AppLayout.setHeaderReveal(), se admite AppLayout.setFooterReveal(). Cuando se llama a AppLayout.setFooterReveal(true), el pie de página será visible en la primera renderización y luego se ocultará cuando el usuario comience a desplazarse hacia arriba. Una vez que el usuario comience a desplazarse hacia abajo nuevamente, el pie de página se revelará.

Por defecto, cuando el ancho de la pantalla es de 800px o menos, el cajón se cambiará al modo de ventana emergente. Esto se llama el punto de ruptura. El modo de ventana emergente significa que el cajón aparecerá sobre el área de contenido con una superposición. Es posible configurar el punto de ruptura utilizando el método setDrawerBreakpoint(), y el punto de ruptura debe ser una consulta de medios válida media query.

Mostrar Código

Utilidades del cajón

Las utilidades del cajón AppLayout están diseñadas para la navegación integrada y menús contextuales dentro del diseño principal de la aplicación, mientras que los componentes Drawer independientes ofrecen paneles deslizantes flexibles e independientes que se pueden usar en cualquier parte de tu aplicación para contenido adicional, filtros o notificaciones. Esta sección se centra en las características y utilidades del cajón integradas proporcionadas por AppLayout.

Punto de ruptura del cajón

Por defecto, cuando el ancho de la pantalla es de 800px o menos, el cajón se cambiará al modo de ventana emergente. Esto se llama el punto de ruptura. El modo de ventana emergente significa que el cajón aparecerá sobre el área de contenido con una superposición. Es posible configurar el punto de ruptura utilizando el método setDrawerBreakpoint(), y el punto de ruptura debe ser una consulta de medios válida.

Por ejemplo, en el siguiente ejemplo, el punto de ruptura del cajón está configurado para ser de 500px o menos.

AppLayout demo = new AppLayout();
demo.setDrawerBreakpoint("(max-width:500px)");

Título del cajón

El componente AppLayout proporciona un método addToDrawerTitle() para definir un título personalizado que se mostrará en el encabezado del cajón.

layout.addToDrawerTitle(new Div("Menú"));

Acciones del cajón

El componente AppLayout te permite colocar componentes personalizados como botones o iconos en el área de acciones del encabezado del cajón utilizando el método addToDrawerHeaderActions().

layout.addToDrawerHeaderActions(
new IconButton(TablerIcon.create("bell")),
);

Es posible pasar múltiples componentes como argumentos:

layout.addToDrawerHeaderActions(
new IconButton(TablerIcon.create("bell")),
new Button("Perfil")
);

Las acciones del cajón aparecen en la sección alineada a la derecha del encabezado del cajón.

Mostrar Código

AppDrawerToggle 24.12

El componente AppDrawerToggle es una clase webforJ del lado del servidor que representa un botón utilizado para alternar la visibilidad de un cajón de navegación en un AppLayout. Se mapea al elemento del lado del cliente <dwc-app-drawer-toggle> y está diseñado por defecto para comportarse como un icono de menú de hamburguesa tradicional, este comportamiento se puede personalizar.

Descripción general

El AppDrawerToggle extiende IconButton y utiliza el icono "menu-2" del conjunto de iconos Tabler por defecto. Aplica automáticamente el atributo data-drawer-toggle para integrarse con el comportamiento del cajón del lado del cliente.

// No se requiere registro de eventos:
AppLayout layout = new AppLayout();
layout.addToHeader(new AppDrawerToggle());
// El botón de alternancia del cajón funcionará sin problemas—no se necesitan oyentes de eventos manuales.

Estilo

Loading...