我找到了更新数据的示例,但它使用了DefaultTableModel。当我创建自己的TableModel和自己的data类时,当我将数据添加到JTable中时,它不会更新。
package by;
import java.awt.BorderLayout;
import java.awt.event.ActionEvent;
import java.util.LinkedList;
import javax.swing.AbstractAction;
import javax.swing.Box;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.SwingUtilities;
import javax.swing.event.TableModelEvent;
import javax.swing.event.TableModelListener;
import javax.swing.table.AbstractTableModel;
public class DialogEg {
private static void createAndShowGui() {
MainWin mainPanel = new MainWin();
JFrame frame = new JFrame("DialogEg");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.getContentPane().add(mainPanel);
frame.pack();
frame.setLocationByPlatform(true);
frame.setVisible(true);
}
public static void main(String[] args) {
SwingUtilities.invokeLater(new Runnable() {
public void run() {
createAndShowGui();
}
});
}
}
class MainWin extends JPanel {
private String[] COL_NAMES = { "Last Name", "First Name" };
//private DefaultTableModel model = new DefaultTableModel(COL_NAMES, 0);
private MyTableModel model = new MyTableModel();
private JTextField lastNameField = new JTextField(15);
private JTextField firstNameField = new JTextField(15);
public MainWin() {
final JPanel dataPanel = new JPanel();
dataPanel.add(new JLabel("Last Name:"));
dataPanel.add(lastNameField);
dataPanel.add(Box.createHorizontalStrut(15));
dataPanel.add(new JLabel("First Name:"));
dataPanel.add(firstNameField);
JPanel btnPanel = new JPanel();
btnPanel.add(new JButton(new AbstractAction("Add Name") {
@Override
public void actionPerformed(ActionEvent arg0) {
lastNameField.setText("");
firstNameField.setText("");
int result = JOptionPane.showConfirmDialog(MainWin.this, dataPanel,
"Enter Name", JOptionPane.OK_CANCEL_OPTION, JOptionPane.PLAIN_MESSAGE);
if (result == JOptionPane.OK_OPTION) {
String lastName = lastNameField.getText();
String firstName = firstNameField.getText();
Object[] dataRow = new String[] { lastName, firstName };
//model.addRow(dataRow);
Person person = new Person();
person.setFirstName(firstName);
person.setLastName(lastName);
model.addElement(person);
model.fireTableDataChanged();
}
}
}));
setLayout(new BorderLayout());
JTable jtable = new JTable(model);
//new JTable(model)
jtable.setModel(model);
add(new JScrollPane(jtable), BorderLayout.CENTER);
add(btnPanel, BorderLayout.SOUTH);
}
}
class MyTableModel extends AbstractTableModel {
private String[] columnNames = {
"Last name",
"First name"
};
//private LinkedList<Person> data = new LinkedList<Person>();
private LinkedList<Person> data = new LinkedList<Person>();
public int getColumnCount() {
return columnNames.length;
}
public int getRowCount() {
return data.size();
}
public String getColumnName(int col) {
return columnNames[col];
}
public Object getValueAt(int row,int col) {
switch(col) {
case 0: {
return data.get(col).getLastName();
}
case 1: {
return data.get(col).getFirstName();
}
default:
return "";
}
}
public void addElement(Person person) {
data.add(person);
}
public void fireTableDataChanged() {
}
}
class Person {
String last_name;
String first_name;
public Person() {
}
public void setLastName(String l_name) {
last_name = l_name;
}
public void setFirstName(String f_name) {
first_name = f_name;
}
public String getLastName() {
return last_name;
}
public String getFirstName() {
return first_name;
}
}
public void actionPerformed(ActionEvent arg0) {
lastNameField.setText("");
firstNameField.setText("");
int result = JOptionPane.showConfirmDialog(MainWin.this, dataPanel,
"Enter Name", JOptionPane.OK_CANCEL_OPTION, JOptionPane.PLAIN_MESSAGE);
if (result == JOptionPane.OK_OPTION) {
String lastName = lastNameField.getText();
String firstName = firstNameField.getText();
Person person = new Person();
person.setFirstName(firstName);
person.setLastName(lastName);
//here i use add element
model.addElement(person);
}
}
有我的桌子模型:
class MyTableModel extends AbstractTableModel {
private String[] columnNames = {
"Last name",
"First name"
};
//private LinkedList<Person> data = new LinkedList<Person>();
private LinkedList<Person> data = new LinkedList<Person>();
public int getColumnCount() {
return columnNames.length;
}
public int getRowCount() {
return data.size();
}
public String getColumnName(int col) {
return columnNames[col];
}
public Object getValueAt(int row,int col) {
switch(col) {
case 0: {
return data.get(col).getLastName();
}
case 1: {
return data.get(col).getFirstName();
}
default:
return "";
}
}
public void addElement(Person person) {
int firstRow = data.size() - 1;
int lastRow = firstRow;
fireTableRowsInserted(firstRow, lastRow);
}
}
当我添加了任何信息,但它没有更新。在JTable中,我必须把这个方法放在哪里来进行正确的数据更新?
你在做两件非常危险的事情:
FireTableDataChanged()
,并给它一个空的方法体,从而绕过super的方法所包含的所有魔力,使它成为一个毫无价值的方法,firexxchanged()
方法。我建议你做完全相反的事情:
FireTableDataChanged()
firexxx()
方法。public void addElement(Person person) {
data.add(person);
int firstRow = data.size() - 1;
int lastRow = firstRow;
fireTableRowsInserted(firstRow, lastRow);
}
// public void fireTableDataChanged() {
//
// }
我认为我必须实现一个firexxx方法。
类扩展AbstractTableModel类而不是实现TableModel接口的原因是为了获得AbstractTableModel类必须提供的所有优点,包括它的firexxx(...)
方法。它们已经连接到通知使用该模型的任何JTables数据已经更改。如果您重写它们,特别是如果您重写它们而不调用任何超级方法,您就破坏了这段有用的代码,它将不再工作。
至于LinkedList,我想尝试使用另一个集合(不像所有示例那样使用数组)。
由于您通常希望以随机的方式访问数据,我认为您可以从ArrayList中获得更多的资金。无论如何,collection变量可能应该是列表接口类型,这样您就可以根据需要更改collection对象的数据类型。
我不明白为什么当我使用您的实现时,它不起作用。
如果您说一些东西“不起作用”,但您没有解释它是如何或为什么不起作用的,您可能看到了哪些错误,并且没有显示您的代码实现,您就束缚了我们的手脚,阻止我们有效地帮助您。如果你需要我们的帮助,考虑给我们足够的信息,让我们了解你的问题。这将包括向我们显示对代码的任何更改,显示任何编译错误或异常消息,以及详细描述问题的细节。
编辑3
在您最近的代码迭代中,您的addElement方法除了添加一个元素之外什么都可以做!
public void addElement(Person person) {
int firstRow = data.size() - 1;
int lastRow = firstRow;
fireTableRowsInserted(firstRow, lastRow);
}
您不需要在上面的方法中向LinkedList添加任何内容!
我现在迷路了。
我有一个大 gui 的 JList,我删除了所有其他不相关的代码。我可以初始化列表,但在使用按钮时无法从中添加/删除项目。我读到的所有内容都说要使用DefaultListModel。然后,当您重新初始化列表时,它将自动更新列表。 我也尝试重新聚焦并重新粉刷面板和框架,但这也不起作用。
问题内容: 我正在通过ng-repeat循环渲染数据。而且我希望它在更新数组时进行更新。从我阅读的内容来看,这应该会自动发生,但是这是行不通的。那我在做什么错? 的HTML: 控制器(此功能通过ng-click在按钮上触发): Console.log显示该数组已正确更新,但是我视图中的表未更改。我不知道我在做什么错。 问题答案: 那是因为您在method中更改了数组引用。 为了避免这种情况,我们使
问题内容: 我对/ 有问题。我的数据表未刷新/更新。我正在使用,根据代码,一切都很好,并且没有任何错误。我也有一个带有分页的表,这就是为什么我使用动作监听器和按钮“上一个”和“下一个”的原因。我正在从其他函数传递到在is中的类中编码的函数 。问题是我填充了包含表数据的数组,但是表不会更新/刷新它。这是我的代码。谢谢前进。 大编辑 旧代码已删除。我添加了新代码,可以帮助您了解我的问题。希望这会有所帮
我试图让我的JTable显示对扩展AbstractTableModel的TableModel所做的更改。我创建了一个堆来插入所有文档,然后在我的堆数组上应用了一个堆排序,所以这个有序的数组应该是我的TableModel数据。它看起来是这样的: 在方法中,当我调用时,堆内部数组将被销毁,它返回一个和有序节点。因此,当有一个带有节点的有序数组时,我的JTable不会显示数据。现在,如果我不执行,而是从
出于某种原因,当这个JTable被调用时,它没有任何变化(这个方法在用户提交SQL查询后更新JTable)。 给定:验证数据向量和列名称向量是否正确填充。JTable 是一个私有类变量。 有什么想法吗?