MaskedTextField
Le composant MaskedTextField fournit une entrée de texte configurable qui impose des règles de formatage et de validation. Il est bien adapté aux applications nécessitant une saisie structurée, telles que les systèmes financiers, de commerce électronique et de santé.
Bases
Le MaskedTextField peut être instancié avec ou sans paramètres. Vous pouvez définir une valeur initiale, une étiquette, un texte d'espace réservé et un écouteur en cas de changement de valeur.
MaskedTextField field = new MaskedTextField("ID de compte");
field.setMask("ZZZZ-0000")
.setHelperText("Masque : ZZZZ-0000 - par exemple : SAVE-2025")
Règles de masque
Le MaskedTextField formate l'entrée de texte en utilisant un masque - une chaîne qui définit quels caractères sont autorisés à chaque position. Cela garantit une saisie cohérente et structurée pour des éléments comme les numéros de téléphone, les codes postaux et les formats d'identification.
Pour formater des chaînes avec la même syntaxe de masque en dehors d'un champ, par exemple lors du rendu de données dans un Table, utilisez la classe utilitaire MaskDecorator.
Caractères de masque pris en charge
| Caractère | Description |
|---|---|
X | Tout caractère imprimable |
a | Tout caractère alphabétique (majuscule ou minuscule) |
A | Tout caractère alphabétique ; les lettres minuscules sont converties en majuscules |
0 | Tout chiffre (0–9) |
z | Tout chiffre ou lettre (majuscule ou minuscule) |
Z | Tout chiffre ou lettre ; les lettres minuscules sont converties en majuscules |
Tous les autres caractères dans le masque sont traités comme des littéraux et doivent être saisis exactement.
Par exemple, un masque comme XX@XX exige que l'utilisateur entre un @ au milieu.
- Caractères invalides sont silencieusement ignorés.
- Saisie courte est complétée par des espaces.
- Saisie longue est tronquée pour s'adapter au masque.
Exemples
field.setMask("(000) 000-0000"); // Exemple : (123) 456-7890
field.setMask("A00 000"); // Exemple : A1B 2C3 (code postal canadien)
field.setMask("ZZZZ-0000"); // Exemple : ABCD-1234
field.setMask("0000-0000-0000-0000");// Exemple : 1234-5678-9012-3456
Si le masque ne contient que des X, le champ se comporte comme un TextField standard, permettant toute saisie imprimable.
Ceci est utile lorsque vous souhaitez réserver la possibilité de formatage sans appliquer de règles strictes sur les caractères.
Afficher le code
- MaskedTextFieldView.java
Modèles de validation
Alors que les masques définissent la structure de l'entrée, vous pouvez les combiner avec des modèles de validation pour imposer des règles d'entrée plus spécifiques. Cela ajoute une couche supplémentaire de validation côté client en utilisant des expressions régulières.
Utilisez la méthode setPattern() pour appliquer une expression régulière personnalisée :
field.setPattern("[A-Za-z0-9]{10}"); // Imposé un code alphanumérique de 10 caractères
Cela garantit que l'entrée non seulement correspond au masque mais se conforme également à une structure définie, comme la longueur ou les caractères autorisés.
Cela est particulièrement utile lorsque :
- Le masque permet trop de flexibilité
- Vous souhaitez imposer une longueur exacte ou un format spécifique (par exemple, hex, Base64, UUID)
Le modèle doit être une expression régulière JavaScript valide, comme utilisé par le type RegExp. Vous trouverez plus de détails dans la documentation de l'attribut de modèle HTML.
Restauration de la valeur
Le MaskedTextField inclut une fonctionnalité de restauration qui réinitialise la valeur du champ à un état prédéfini ou d'origine.
Cela peut être utile pour annuler les modifications de l'utilisateur ou revenir à une saisie par défaut.
field.setRestoreValue("ABC123");
field.restoreValue();
Méthodes pour 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 remplacée par un écouteur d'événements)
Vous pouvez définir la valeur à restaurer avec setRestoreValue(). Si aucune valeur de restauration n'est définie, le champ reviendra à la valeur initiale au moment où il a été rendu.
Afficher le code
- MaskedTextFieldRestoreView.java
MaskedTextFieldSpinner
Le MaskedTextFieldSpinner étend MaskedTextField en ajoutant des contrôles de sélecteur qui permettent aux utilisateurs de faire défiler une liste de valeurs prédéfinies.
Cela améliore l'expérience utilisateur dans les situations où l'entrée doit être contrainte à un ensemble fixe d'options valides.
Afficher le code
- MaskedTextFieldSpinnerView.java
Caractéristiques clés
-
Support de liste d'options
Remplissez le sélecteur avec une liste de valeurs de chaîne valides en utilisantsetOptions():spinner.setOptions(List.of("Option A", "Option B", "Option C")); -
Défilement par programme
UtilisezspinUp()etspinDown()pour parcourir les options :spinner.spinUp(); // Sélectionne l'option suivante
spinner.spinDown(); // Sélectionne l'option précédente -
Contrôle de l'index
Définissez ou récupérez l'index de sélection actuel avec :spinner.setOptionIndex(1);
int current = spinner.getOptionIndex(); -
Compatibilité de masque
Hérite entièrement de toutes les règles de formatage, de masques et de validation des modèles deMaskedTextField.