Saltar al contenido principal

DateField

Abrir en ChatGPT
Sombra dwc-field 23.02
Java API

El componente DateField permite a los usuarios ingresar o seleccionar una fecha por año, mes y día. Maneja la validación automáticamente, por lo que las fechas mal formateadas se detectan antes de enviar el formulario.

Usando DateField

Inheritance

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

DateField extiende la clase compartida Field, que proporciona características comunes a todos los componentes de campo. El siguiente ejemplo crea DateFields de salida y regreso que se mantienen sincronizados, con restricciones mínimas y máximas para limitar el rango seleccionable.

Mostrar Código

Valor del campo (LocalDate)

El componente DateField almacena su valor internamente como un objeto LocalDate, que representa una fecha sin información de tiempo o zona horaria. Esto permite un manejo preciso de entradas basadas en el calendario a través de diferentes sistemas.

Valor mostrado VS valor analizado

Mientras que el valor mostrado se adapta a la configuración regional del navegador del usuario, asegurando un formato familiar regionalmente (por ejemplo, MM/DD/YYYY en los Estados Unidos o DD.MM.YYYY en Europa), el valor analizado siempre se basa en el formato fijo de yyyy-MM-dd.

Obtener y establecer el valor LocalDate

Para recuperar el valor actual, usa el método getValue():

LocalDate value = dateField.getValue();

Para establecer el valor programáticamente, usa el método setValue():

dateField.setValue(LocalDate.of(2024, 4, 27));

Usando setText()

También puedes asignar un valor usando una cadena sin procesar, pero debe seguir el formato exacto yyyy-MM-dd:

dateField.setText("2024-04-27"); // válido

dateField.setText("04/27/2024"); // inválido
advertencia

Cuando se utiliza el método setText(), se lanzará un IllegalArgumentException si el componente no puede analizar la entrada en el formato yyyy-MM-dd.

Usos

El DateField es ideal para elegir y mostrar fechas en tu aplicación. Aquí hay algunos ejemplos de cuándo usar el DateField:

  1. Programación de Eventos y Calendarios: Los campos de fecha son esenciales en aplicaciones que implican la programación de eventos, la reserva de citas o el seguimiento de fechas importantes.

  2. Entradas de Formularios: Simplifica el proceso de selección de fechas para un usuario que completa un formulario que requiere una fecha, como un cumpleaños.

  3. Sistemas de Reservas y Reservaciones: Las aplicaciones que implican sistemas de reservas a menudo requieren que los usuarios ingresen fechas específicas. Un campo de fecha agiliza el proceso y asegura una selección precisa de fechas.

  4. Gestión de Tareas y Plazos: Los campos de fecha son valiosos en aplicaciones que involucran la gestión de tareas o el establecimiento de plazos. Los usuarios pueden especificar fácilmente fechas de vencimiento, fechas de inicio u otra información sensible al tiempo.

Valor mínimo y máximo

El valor mínimo

El método setMin() define la fecha más temprana que un usuario puede ingresar en el componente. Si la entrada es anterior a la mínima especificada, fallará la validación de restricciones. Cuando se utiliza junto con setMax(), el mínimo debe ser una fecha que sea igual o anterior al máximo.

dateField.setMin(LocalDate.of(2023, 1, 1)); // Mínimo permitido: 1 de enero de 2023

El valor máximo

El método setMax() define la fecha más reciente que el componente acepta. Si la fecha ingresada es posterior a la máxima especificada, la entrada es inválida. Cuando ambos valores están definidos, el máximo debe ser una fecha que sea igual o posterior al mínimo.

dateField.setMax(LocalDate.of(2023, 12, 31)); // Máximo permitido: 31 de diciembre de 2023

Utilidades estáticas

La clase DateField también proporciona los siguientes métodos de utilidad estáticos:

  • fromDate(String dateAsString): Convierte una cadena de fecha en formato yyyy-MM-dd a un objeto LocalDate que luego se puede utilizar con este campo, o en otros lugares.

  • toDate(LocalDate date): Convierte un objeto LocalDate a una cadena de fecha en formato yyyy-MM-dd.

  • isValidDate(String dateAsString): Comprueba si la cadena dada es una fecha válida en formato yyyy-MM-dd.

Mejores prácticas

Para asegurar una experiencia óptima del usuario al usar el componente DateField, considera las siguientes mejores prácticas:

  • Accesibilidad: Utiliza etiquetas apropiadas para asegurar que los usuarios con tecnologías de asistencia puedan navegar y usar fácilmente los campos de fecha en tu aplicación.

  • Auto-rellenar la Fecha Actual: Si es apropiado para el caso de uso de tu aplicación, auto-rellena el campo de fecha con la fecha actual.