Maison > Java > javaDidacticiel > Voici quelques options de titre basées sur des questions et correspondant au contenu de l'article : * Comment appliquer des règles de validation personnalisées pour les cellules JTable ? * Comment puis-je créer un éditeur de cellules personnalisé pour rejeter Inv

Voici quelques options de titre basées sur des questions et correspondant au contenu de l'article : * Comment appliquer des règles de validation personnalisées pour les cellules JTable ? * Comment puis-je créer un éditeur de cellules personnalisé pour rejeter Inv

DDD
Libérer: 2024-10-27 09:44:30
original
306 Les gens l'ont consulté

Here are a few title options that are question-based and match the article's content:

* How to Enforce Custom Validation Rules for JTable Cells?
* How can I Create a Custom Cell Editor to Reject Invalid Input in JTable?
* Beyond Type Checking: Implement

Comment rejeter les entrées non valides dans les cellules JTable

Dans JTable, la définition du type de classe de colonne garantit que les entrées non valides sont automatiquement rejetées avec un rouge contour, comme on le voit lors de la saisie de valeurs doubles dans une colonne entière. Cependant, ce comportement ne s'étend pas aux règles de validation personnalisées, telles que le rejet des valeurs négatives ou nulles.

Pour reproduire le comportement de rejet automatique pour les entrées non positives, nous pouvons créer un éditeur de cellule personnalisé qui vérifie la validité. pendant l'édition de cellule.

PositiveIntegerCellEditor

Le PositiveIntegerCellEditor suivant étend l'éditeur de cellule par défaut pour effectuer la validation souhaitée :

<code class="java">private static class PositiveIntegerCellEditor extends DefaultCellEditor {

    private static final Border red = new LineBorder(Color.red);
    private static final Border black = new LineBorder(Color.black);
    private JTextField textField;

    public PositiveIntegerCellEditor(JTextField textField) {
        super(textField);
        this.textField = textField;
        this.textField.setHorizontalAlignment(JTextField.RIGHT);
    }

    @Override
    public boolean stopCellEditing() {
        try {
            int v = Integer.valueOf(textField.getText());
            if (v < 0) {
                throw new NumberFormatException();
            }
        } catch (NumberFormatException e) {
            textField.setBorder(red);
            return false;
        }
        return super.stopCellEditing();
    }

    @Override
    public Component getTableCellEditorComponent(JTable table,
        Object value, boolean isSelected, int row, int column) {
        textField.setBorder(black);
        return super.getTableCellEditorComponent(
            table, value, isSelected, row, column);
    }
}</code>
Copier après la connexion

Utilisation

Lors de la modification d'une cellule dans la colonne spécifiée, PositiveIntegerCellEditor rejettera les entrées non positives, délimitera la cellule en rouge et empêchera la fin de l'édition de la cellule.

Le code fourni inclut également des améliorations pour l'alignement à droite et la gestion des erreurs lors de l'édition de cellules.

Addendum

L'article fournit également des liens vers des ressources supplémentaires sur la validation de l'édition de cellules dans JTable.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal