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
DDDoriginal
2024-10-27 09:44:30344parcourir

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>

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!

Déclaration:
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