DateField
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 formateadas incorrectamente se detectan antes de que se envíe el formulario.
Usando DateField
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 Field compartida, que proporciona características comunes en todos los componentes de campo. El siguiente ejemplo crea DateFields de salida y retorno que permanecen sincronizados, con restricciones mínimas y máximas para limitar el rango seleccionable.
Mostrar Código
- Java
Valor del campo (LocalDate)
El componente DateField almacena su valor internamente como un objeto LocalDate, que representa una fecha sin información de hora o zona horaria. Esto permite un manejo preciso de entradas basadas en calendario a través de diferentes sistemas.
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 de LocalDate
Para recuperar el valor actual, utiliza 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"); // no válido
Al usar el método setText(), se lanzará una 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:
-
Programación de Eventos y Calendarios: Los campos de fecha son esenciales en aplicaciones que involucran la programación de eventos, la reserva de citas o el seguimiento de fechas importantes.
-
Entradas de Formularios: Simplifican el proceso de selección de fechas para un usuario que completa un formulario que requiere una fecha, como un cumpleaños.
-
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 de fecha precisa.
-
Gestión de Tareas y Plazos: Los campos de fecha son valiosos en aplicaciones que implican gestión de tareas o 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 usa junto con setMax(), la mínima debe ser una fecha que sea la misma o anterior a la máxima.
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 última fecha que acepta el componente. Si la fecha ingresada es posterior a la máxima especificada, la entrada es no válida. Cuando se definen ambos valores, la máxima debe ser una fecha que sea la misma o posterior a la mínima.
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 formatoyyyy-MM-dda un objetoLocalDate, que puede ser utilizado con este campo, o en otros lugares. -
toDate(LocalDate date): Convierte un objetoLocalDatea una cadena de fecha en formatoyyyy-MM-dd. -
isValidDate(String dateAsString): Verifica si la cadena dada es una fecha válidayyyy-MM-dd.
Mejores prácticas
Para asegurar una experiencia óptima para el 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.
-
Autocompletar la Fecha Actual: Si es apropiado para el caso de uso de tu aplicación, autocompleta el campo de fecha con la fecha actual.