繁体   English   中英

刷新JTable中的所有数据

[英]Refresh all data in JTable

我已经看到很多使用以下方法刷新JTable的线程:

String[] columnNames = {"column1","column2,......,"columnN"};
String[][] tableData = new String[1][columnNames.length];
JTable table = new JTable(tableData,columnNames);

JScrollPane scrollpane = new JScrollPane(table);
contentPane.add(scrollpane);

...对存储在tableData的数据进行更改,然后调用...

AbstractTableModel model = (AbstractTableModel) table.getModel();
model.fireTableDataChanged();

但这似乎对我没有任何改变。 我首先需要显示显示一行空白表,然后在用户加载数据文件时对其进行更新,但是下面的代码似乎对我不起作用。 我认为这是因为我正在重新定义tableData但是必须这样做,因为在用户加载文件之前,我不知道要显示多少行数据。 如何更新表格?


编辑:为了更清楚我正在运行的代码是:

//Initialize Table With 1 Blank Row
String[] columnNames = {"column1","column2,......,"columnN"};
String[][] tableData = new String[1][columnNames.length];
JTable table = new JTable(tableData,columnNames);

JScrollPane scrollpane = new JScrollPane(table);
contentPane.add(scrollpane);

//When the file is loaded resize tableData so it can fit all the file data
tableData = new String[length of data file][columnNames.length];

//Update some of the tableData points
tableData[0][0]="data 1";
tableData[1][0]="data 2";
tableData[0][1]="data 3";
tableData[1][1]="data 4";
....etc

//Tell the JTable to update
AbstractTableModel model = (AbstractTableModel) table.getModel();
model.fireTableDataChanged();

我认为问题在于,当您创建JTable时,您并未为其分配任何模型。

参见以下示例:

这里太多了,但是您会明白的。

import java.awt.EventQueue;

import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableModel;
import javax.swing.JButton;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;

public class TestGUI {

    private JFrame frame;
    private JTable table;

    /**
     * Launch the application.
     */
    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {
            public void run() {
                try {
                    TestGUI window = new TestGUI();
                    window.frame.setVisible(true);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        });
    }

    /**
     * Create the application.
     */
    public TestGUI() {
        initialize();
    }

    /**
     * Initialize the contents of the frame.
     */
    private void initialize() {
        frame = new JFrame();
        frame.setBounds(100, 100, 450, 300);
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.getContentPane().setLayout(null);

        JScrollPane scrollPane = new JScrollPane();
        scrollPane.setBounds(60, 81, 311, 96);

        frame.getContentPane().add(scrollPane);

        String[] columnNames = { "column1", "column2", "columnN" };
        String[][] tableData = new String[1][columnNames.length];
        table = new JTable(tableData, columnNames);
        DefaultTableModel model = new DefaultTableModel(2, columnNames.length);
        model.addRow(new String[] { "A", "B", "C" });
        table.setModel(model);

        scrollPane.setViewportView(table);

        JButton btnNewButton = new JButton("update");
        btnNewButton.addActionListener(new ActionListener() {
            public void actionPerformed(ActionEvent e) {

                DefaultTableModel model = (DefaultTableModel) table.getModel();
                model.addRow(new String[] { "A", "B", "D" });

            }
        });
        btnNewButton.setBounds(49, 199, 89, 23);
        frame.getContentPane().add(btnNewButton);
    }
}

您的示例将永远无法工作,因为DefaultTableModel (默认情况下在此使用)会将所有数组数据复制到内部向量对象中。 因此,您对原始数组所做的更改将永远不会传播到DefaultTableModel的内部结构。

直接使用DefaultTableModel可以避免出现问题。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM