TableModelListener和多列validation

这是我第一次在这里发帖,如果我犯了一些错误就很抱歉。

我正在研究JTable哪个列数据必须validation一些参数,例如:

第3列值> 30
第4列值> 10
第5列值> 4

前两列也是“自动”填充的,在其余列中加0。

如果该数据是正确的,在第5列中我会显示一个勾号图像,否则,我会显示一个警告图像。

为了validation这一点,我使用以下代码

ImageIcon accept = new javax.swing.ImageIcon(getClass().getResource("/resources/accept.png")); ImageIcon deny = new javax.swing.ImageIcon(getClass().getResource("/resources/exclamation.png")); public void tableChanged(TableModelEvent e) { int row = e.getFirstRow(); double d1 = Double.valueOf(jTable.getValueAt(row, 2).toString()); double d2 = Double.valueOf(jT.getValueAt(row, 3).toString()); double d3 = Double.valueOf(jT.getValueAt(row, 4).toString()); if(d1>MAX_A||d2>MAX_B||d3>MAX_C){ jTable.setValueAt(deny, row, 5); } else{ jTable.setValueAt(accept, row, 5); } } 

这段代码的问题是返回Stack Overflow,我不知道如何处理它。

有没有其他方法在表示多个单元格的表上实现某些validation程序?

提前致谢。

这段代码的问题是返回Stack Overflow,我不知道如何处理它。

问题是您的代码在模型侦听器中设置了一个值,因此生成了另一个tableChanged事件。 你的代码应该是这样的:

 if (e.getColumn() != 5) // do your code 

我没有看到使用TableModelListener根据另一列中的数据动态设置列值的问题。 这是一个简单的例子:

 import java.awt.*; import javax.swing.*; import javax.swing.event.*; import javax.swing.table.*; public class TableProcessing extends JFrame implements TableModelListener { JTable table; public TableProcessing() { super("Table"); String[] columnNames = {"Item", "Quantity", "Price", "Cost"}; Object[][] data = { {"Bread", new Integer(1), new Double(1.11), new Double(1.11)}, {"Milk", new Integer(1), new Double(2.22), new Double(2.22)}, {"Tea", new Integer(1), new Double(3.33), new Double(3.33)}, {"Cofee", new Integer(1), new Double(4.44), new Double(4.44)} }; DefaultTableModel model = new DefaultTableModel(data, columnNames); model.addTableModelListener( this ); // table = new JTable( model ) { // Returning the Class of each column will allow different // renderers to be used based on Class public Class getColumnClass(int column) { return getValueAt(0, column).getClass(); } // The Cost is not editable public boolean isCellEditable(int row, int column) { int modelColumn = convertColumnIndexToModel( column ); return (modelColumn == 3) ? false : true; } }; table.setPreferredScrollableViewportSize(table.getPreferredSize()); // JScrollPane scrollPane = new JScrollPane( table ); getContentPane().add( scrollPane ); String[] items = { "Bread", "Milk", "Tea", "Coffee" }; JComboBox editor = new JComboBox( items ); DefaultCellEditor dce = new DefaultCellEditor( editor ); table.getColumnModel().getColumn(0).setCellEditor(dce); } /* * The cost is recalculated whenever the quantity or price is changed */ public void tableChanged(TableModelEvent e) { if (e.getType() == TableModelEvent.UPDATE) { int row = e.getFirstRow(); int column = e.getColumn(); if (column == 1 || column == 2) { TableModel model = table.getModel(); int quantity = ((Integer)model.getValueAt(row, 1)).intValue(); double price = ((Double)model.getValueAt(row, 2)).doubleValue(); Double value = new Double(quantity * price); model.setValueAt(value, row, 3); } } } public static void main(String[] args) { TableProcessing frame = new TableProcessing(); frame.setDefaultCloseOperation( EXIT_ON_CLOSE ); frame.pack(); frame.setLocationRelativeTo( null ); frame.setVisible(true); } } 

由于getFirstRow调用,您可能会收到错误。 我认为在JTable.tableChangedvalidation表结构是个坏主意 – 你怎么知道表已经完全填满并准备好进行validation? 我建议先填写整个表格,然后再调试validation。 也许使用单独的表来显示validation结果也是个好主意