MaskedDateField
Le MaskedDateField est un champ de texte qui permet aux utilisateurs d'entrer des dates sous forme de chiffres et formate automatiquement l'entrée en fonction d'un masque défini lorsque le champ perd le focus. Le masque spécifie le format de date attendu, guidant à la fois l'entrée et l'affichage. Le composant prend en charge l'analyse flexible, la validation, la localisation et la restauration des valeurs pour un traitement cohérent et spécifique à la région des dates.
Bases
Le MaskedDateField est uniquement axé sur les valeurs de date. Si vous avez besoin d'un composant similaire pour entrer et formatter l'heure, jetez un œil au MaskedTimeField.
Le MaskedDateField peut être instancié avec ou sans paramètres. Vous pouvez définir une valeur initiale, une étiquette, un espace réservé et un écouteur d'événements pour les changements de valeur.
Afficher le code
- MaskedDateFieldView.java
Règles de masque
Le MaskedDateField prend en charge plusieurs formats de date utilisés dans le monde, qui varient selon l'ordre du jour, du mois et de l'année. Les modèles communs incluent :
- Jour/Mois/Année (utilisé dans la plupart des pays européens)
- Mois/Jour/Année (utilisé aux États-Unis)
- Année/Mois/Jour (utilisé en Chine, au Japon et en Corée; également la norme ISO :
YYYY-MM-DD)
Au sein de ces formats, des variations locales incluent le choix du séparateur (par exemple, -, /, ou .), si les années sont sur deux ou quatre chiffres, et si les mois ou jours à un chiffre sont remplis de zéros devant.
Pour gérer cette diversité, le MaskedDateField utilise des indicateurs de format, chacun commençant par %, suivi d'une lettre représentant une partie spécifique de la date. Ces indicateurs définissent comment l'entrée est analysée et comment la date est affichée.
Pour formatter ou analyser des dates avec la même syntaxe de masque en dehors d'un champ, utilisez la classe utilitaire MaskDecorator.
Indicateurs de format de date
| Format | Description |
|---|---|
%Y | Année |
%M | Mois |
%D | Jour |
Modificateurs
Les modificateurs permettent un contrôle supplémentaire sur la façon dont les composants de la date sont formatés :
| Modificateur | Description |
|---|---|
z | Remplissage de zéros |
s | Représentation textuelle courte |
l | Représentation textuelle longue |
p | Nombre compact |
d | Décimal (format par défaut) |
Ces modificateurs peuvent être combinés pour créer une large variété de masques de date.
Localisation des formats de date
Le MaskedDateField s'adapte aux formats de date régionaux en définissant la culture appropriée. Cela garantit que les dates sont affichées et analysées d'une manière conforme aux attentes des utilisateurs.
| Région | Format | Exemple |
|---|---|---|
| États-Unis | MM/DD/YYYY | 07/04/2023 |
| Europe | DD/MM/YYYY | 04/07/2023 |
| Norme ISO | YYYY-MM-DD | 2023-07-04 |
Pour appliquer la localisation, utilisez la méthode setLocale(). Elle accepte un java.util.Locale et ajuste automatiquement le formatting et l'analyse :
dateField.setLocale(Locale.FRANCE);
Logique d'analyse
Le MaskedDateField analyse l'entrée de l'utilisateur en fonction du masque de date défini. Il accepte des entrées numériques complètes et abrégées avec ou sans délimiteurs, permettant une saisie flexible tout en garantissant des dates valides. Le comportement d'analyse dépend de l'ordre du format défini par le masque (par exemple, %Mz/%Dz/%Yz pour mois/jour/année). Ce format détermine comment les séquences numériques sont interprétées.
Par exemple, en supposant que nous sommes le 15 septembre 2012, voici comment diverses entrées seraient interprétées :
Scénarios d'analyse d'exemple
| Entrée | YMD (ISO) | MDY (US) | DMY (EU) |
|---|---|---|---|
1 | Un chiffre unique est toujours interprété comme un numéro de jour dans le mois actuel, donc cela serait le 1 septembre 2012. | Identique à YMD | Identique à YMD |
12 | Deux chiffres sont toujours interprétés comme un numéro de jour dans le mois actuel, donc cela serait le 12 septembre 2012. | Identique à YMD | Identique à YMD |
112 | Trois chiffres sont interprétés comme un numéro de mois à un chiffre suivi d'un numéro de jour à deux chiffres, donc cela serait le 12 janvier 2012. | Identique à YMD | Trois chiffres sont interprétés comme un numéro de jour à un chiffre suivi d'un numéro de mois à deux chiffres, donc cela serait le 1 décembre 2012. |
1004 | Quatre chiffres sont interprétés comme MMDD, donc cela serait le 4 octobre 2012. | Identique à YMD | Quatre chiffres sont interprétés comme DDMM, donc cela serait le 10 avril 2012. |
020304 | Six chiffres sont interprétés comme YYMMDD, donc cela serait le 4 mars 2002. | Six chiffres sont interprétés comme MMDDYY, donc cela serait le 3 février 2004. | Six chiffres sont interprétés comme DDMMYY, donc cela serait le 2 mars 2004. |
8 chiffres | Huit chiffres sont interprétés comme YYYYMMDD. Par exemple, 20040612 est le 12 juin 2004. | Huit chiffres sont interprétés comme MMDDYYYY. Par exemple, 06122004 est le 12 juin 2004. | Huit chiffres sont interprétés comme DDMMYYYY. Par exemple, 06122004 est le 6 décembre 2004. |
12/6 | Deux nombres séparés par un délimiteur valide sont interprétés comme MM/DD, donc cela serait le 6 décembre 2012. Remarque : Tous les caractères, sauf les lettres et les chiffres, sont considérés comme des délimiteurs valides. | Identique à YMD | Deux nombres séparés par un délimiteur sont interprétés comme DD/MM, donc cela serait le 12 juin 2012. |
3/4/5 | 5 avril 2012 | 4 mars 2005 | 3 avril 2005 |
Analyse de date textuelle 25.11
Par défaut, le MaskedDateField n'accepte que des entrées numériques pour les dates. Cependant, vous pouvez activer l'analyse de date textuelle pour permettre aux utilisateurs d'entrer des noms de mois et de jour dans leur saisie. Cette fonctionnalité est particulièrement utile pour créer une saisie de date plus naturelle.
Pour activer l'analyse textuelle, utilisez la méthode setTextualDateParsing() :
dateField.setTextualDateParsing(true);
Substitution de nom de mois
Lorsque l'analyse textuelle est activée, vous pouvez utiliser des modificateurs spéciaux dans votre masque pour accepter des noms de mois au lieu de valeurs numériques :
%Ms- Accepte les noms de mois courts (Jan, Feb, Mar, etc.)%Ml- Accepte les noms de mois longs (Janvier, Février, Mars, etc.)
Les noms de mois peuvent apparaître à n'importe quelle position dans le masque, et le champ acceptera toujours une entrée numérique comme secours.
Exemples
| Masque | Entrée | Résultat |
|---|---|---|
%Ms/%Dz/%Yz | Sep/01/25 | Valide - Analyse comme le 1 septembre 2025 |
%Ml/%Dz/%Yz | Septembre/01/25 | Valide - Analyse comme le 1 septembre 2025 |
%Dz/%Ml/%Yz | 01/Septembre/25 | Valide - Analyse comme le 1 septembre 2025 |
%Mz/%Dz/%Yz | 09/01/25 | Valide - Le secours numérique fonctionne toujours |
Les 12 mois sont pris en charge sous les formes courtes (Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, Dec) et longues (Janvier, Février, etc.).
Décoration du nom du jour
Les noms de jours de la semaine peuvent être inclus dans l'entrée pour une meilleure lisibilité, mais ils sont uniquement décoratifs et sont supprimés lors de l'analyse. Ils n'affectent pas la valeur réelle de la date.
%Ds- Accepte les noms de jours courts (Lun, Mar, Mer, etc.)%Dl- Accepte les noms de jours longs (Lundi, Mardi, Mercredi, etc.)
Lors de l'utilisation des noms de jours de la semaine (%Ds ou %Dl), votre masque doit également inclure %Dz ou %Dd pour spécifier le numéro de jour réel. Sans un composant de jour numérique, l'entrée sera invalide.
Exemples
| Masque | Entrée | Résultat |
|---|---|---|
%Ds %Mz/%Dz/%Yz | Lun 09/01/25 | Valide - Le nom du jour est décoratif |
%Dl %Mz/%Dz/%Yz | Lundi 09/01/25 | Valide - Le nom du jour est décoratif |
%Mz/%Dz/%Yz %Ds | 09/01/25 Mar | Valide - Le nom du jour à la fin |
%Dl/%Mz/%Yz | Lundi/09/25 | Invalide - Manque %Dz |
%Mz/%Dl/%Yz | 09/Lundi/25 | Invalide - Manque %Dz |
Les 7 jours de la semaine sont pris en charge dans les formes courtes (Lun, Mar, Mer, Jeu, Ven, Sam, Dim) et longues (Lundi, Mardi, etc.).
Règles d'analyse supplémentaires
L'analyse de date textuelle comprend plusieurs fonctionnalités utiles :
- Insensible à la casse : Des entrées telles que
LUNDI 09/01/25,lundi 09/01/25, ouLundi 09/01/25fonctionnent de la même manière. - Consciente de la culture : Les noms de mois et de jours doivent correspondre à la culture configurée du champ. Par exemple, avec une culture française, utilisez
septembreet nonSeptember. Les noms anglais ne seront reconnus que si la culture est définie sur l'anglais.- Culture française :
septembre/01/25est reconnu comme septembre - Culture allemande :
Montag 09/01/25est reconnu avec lundi comme nom du jour
- Culture française :
Définition des contraintes min/max
Vous pouvez restreindre la plage de dates autorisées dans un MaskedDateField en utilisant les méthodes setMin() et setMax() :
dateField.setMin(LocalDate.of(2020, 1, 1));
dateField.setMax(LocalDate.of(2030, 12, 31));
Les deux méthodes acceptent des valeurs de type java.time.LocalDate. Les entrées en dehors de la plage définie seront considérées comme invalides.
Restauration de la valeur
Le MaskedDateField comprend une fonctionnalité de restauration qui réinitialise la valeur du champ à un état prédéfini ou original. Cela est utile pour rétablir l'entrée de l'utilisateur ou pour revenir à une date par défaut.
dateField.setRestoreValue(LocalDate.of(2025, 1, 1));
dateField.restoreValue();
Manières de restaurer la valeur
- Par programme, en appelant
restoreValue() - Via le clavier, en appuyant sur ESC (c'est la touche de restauration par défaut, sauf si elle est remplacée par un écouteur d'événements)
Vous pouvez définir la valeur à restaurer avec setRestoreValue(), en passant une instance de LocalDate.
Afficher le code
- MaskedDateFieldRestoreView.java
Modèles de validation
Vous pouvez appliquer des règles de validation côté client à l'aide d'expressions régulières avec la méthode setPattern() :
dateField.setPattern("^\\d{2}/\\d{2}/\\d{4}$");
Ce modèle garantit que seules les valeurs correspondant au format MM/JJ/AAAA (deux chiffres, barre oblique, deux chiffres, barre oblique, quatre chiffres) sont considérées comme valides.
Le modèle doit suivre la syntaxe RegExp de JavaScript telle que documentée ici.
Le champ tente d'analyser et de formatter les entrées de date numériques en fonction du masque actuel. Cependant, les utilisateurs peuvent toujours entrer manuellement des valeurs qui ne correspondent pas au format attendu. Si l'entrée est syntaxiquement valide mais sémantiquement incorrecte ou inanalysable (par exemple 99/99/9999), elle peut passer les vérifications de modèle mais échouer à la validation logique.
Vous devez toujours valider la valeur d'entrée dans la logique de votre application, même si un motif d'expression régulière est défini, pour vous assurer que la date est à la fois correctement formatée et significative.
Sélecteur de date
Le MaskedDateField comprend un sélecteur de calendrier intégré qui permet aux utilisateurs de sélectionner une date visuellement, plutôt que de la taper. Cela améliore l'utilisabilité pour les utilisateurs moins techniques ou lorsque des entrées précises sont requises.
Afficher le code
- MaskedDateFieldPickerView.java
Accéder au sélecteur
Vous pouvez accéder au sélecteur de date en utilisant getPicker() :
DatePicker picker = dateField.getPicker();
Afficher/cacher l'icône du sélecteur
Utilisez setIconVisible() pour afficher ou masquer l'icône de calendrier à côté du champ :
picker.setIconVisible(true); // montre l'icône
Comportement d'ouverture automatique
Vous pouvez configurer le sélecteur pour qu'il s'ouvre automatiquement lorsque l'utilisateur interagit avec le champ (par exemple, en cliquant, en appuyant sur Entrée ou sur les touches fléchées) :
picker.setAutoOpen(true);
Pour garantir que les utilisateurs ne peuvent sélectionner une date qu'à l'aide du sélecteur de calendrier (et non pas en saisissant manuellement), combinez les deux réglages suivants :
dateField.getPicker().setAutoOpen(true); // Ouvre le sélecteur lors de l'interaction de l'utilisateur
dateField.setAllowCustomValue(false); // Désactive la saisie de texte manuelle
Cette configuration garantit que toutes les entrées de date viennent via l'interface utilisateur du sélecteur, ce qui est utile lorsque vous souhaitez un contrôle strict du format et éliminer les problèmes d'analyse provenant des saisies de texte.
Ouvrir manuellement le calendrier
Pour ouvrir le calendrier par programme :
picker.open();
Ou utilisez l'alias :
picker.show(); // identique à open()
Afficher les semaines dans le calendrier
Le sélecteur peut afficher des numéros de semaine dans la vue du calendrier :
picker.setShowWeeks(true);
MaskedDateFieldSpinner
Le MaskedDateFieldSpinner étend MaskedDateField en ajoutant des contrôles de spinner qui permettent aux utilisateurs d'incrémenter ou de décrémenter la date à l'aide des touches fléchées ou des boutons de l'interface utilisateur. Il fournit un style d'interaction plus guidé, particulièrement utile dans les applications de type bureau.
Afficher le code
- MaskedDateFieldSpinnerView.java
Principales caractéristiques
-
Pas de date interactive :
Utilisez les touches fléchées ou les boutons de défilement pour incrémenter ou décrémenter la valeur de la date. -
Unité de pas personnalisable :
Choisissez quelle partie de la date modifier à l'aide desetSpinField():spinner.setSpinField(MaskedDateFieldSpinner.SpinField.MONTH);Les options incluent
DAY,WEEK,MONTH, etYEAR. -
Limites min/max :
Hérite du support pour les dates minimales et maximales autorisées à l'aide desetMin()etsetMax(). -
Sortie formatée :
Complètement compatible avec les masques et les paramètres de localisation duMaskedDateField.
Exemple : Configurer des pas hebdomadaires
MaskedDateFieldSpinner spinner = new MaskedDateFieldSpinner();
spinner.setSpinField(MaskedDateFieldSpinner.SpinField.WEEK);
Cela fait que chaque étape de défilement avance ou recule la date d'une semaine.