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.
El DateField
es un componente de campo que permite a los usuarios ingresar o seleccionar fechas por año, mes y día. Proporciona una manera intuitiva y eficiente de manejar información relacionada con fechas en diversas aplicaciones, y ofrece la flexibilidad de validar la entrada del usuario.
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 tiempo o zona horaria. Esto permite un manejo preciso de entradas relacionadas con el calendario en diferentes sistemas.
Mientras que el valor mostrado se adapta a la configuración regional del navegador del usuario, asegurando un formato familiar regional (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, utiliza el método getValue()
:
LocalDate value = dateField.getValue();
Para establecer el valor de manera programática, utiliza el método setValue()
:
dateField.setValue(LocalDate.of(2024, 4, 27));
Usando setText()
También puedes asignar un valor usando una cadena de texto 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
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: Simplifica el proceso de selección de fechas para un usuario que llena un formulario que requiere una fecha, como un cumpleaños.
-
Sistemas de reservas y reservas: Las aplicaciones que involucran 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 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()
, 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 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, 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-dd
a un objetoLocalDate
, que luego puede ser utilizado con este campo, o en otros lugares. -
toDate(LocalDate date)
: Convierte un objetoLocalDate
a una cadena de fecha en formatoyyyy-MM-dd
. -
isValidDate(String dateAsString)
: Verifica si la cadena dada es una fecha válida en formatoyyyy-MM-dd
.
Mejores prácticas
Para asegurar una experiencia óptima del usuario al utilizar el componente DateField
, considera las siguientes mejores prácticas:
-
Accesibilidad: Utiliza etiquetas adecuadas para asegurar que los usuarios con tecnologías asistivas puedan navegar y usar fácilmente los campos de fecha en tu aplicación.
-
Autocompletar con la fecha actual: Si es apropiado para el caso de uso de tu aplicación, autocompleta el campo de fecha con la fecha actual.