在第一次取回数据库内容并显示后 再取得另一些数据刷新表格内容无法显示用frame.repaint()
并没有用 该怎么办
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
参考示例代码:
User {
private String id;
private String name;
public User() {
}
public User(String id, String name) {
this.id = id;
this.name = name;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
UserTableModel extends AbstractTableModel {
private static final long serialVersionUID = 1L;
// 保存一个User的列表
private List<User> users = new ArrayList<User>();
// 设置User列表, 同时通知JTabel数据对象更改, 重绘界面
public void setUsers(List<User> users) {
this.users = users;
this.fireTableDataChanged();// 同时通知JTabel数据对象更改, 重绘界面
}
public int getColumnCount() {
return 2;
}
public int getRowCount() {
return users.size();
}
// 从list中拿出rowIndex行columnIndex列显示的值
public Object getValueAt(int rowIndex, int columnIndex) {
User user = users.get(rowIndex);
if (columnIndex == 0) {
return user.getId();
} else {
return user.getName();
}
}
}
public class userjtable {
public static void main(String args[]) {
JFrame frame = new JFrame();
frame.setBounds(100, 100, 500, 375);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
JTable table = new JTable();
final UserTableModel userTableModel = new UserTableModel();
userTableModel.setUsers(Arrays.asList(new User("1", "fuxueliang")));
table.setModel(userTableModel);
frame.getContentPane().setLayout(new BorderLayout());
frame.getContentPane().add("Center", table);
JButton button = new JButton("Change Model");
button.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
String current = String.valueOf(System.currentTimeMillis());
// 注意:这里修改了UserTableModel的list, 这个list可以是你从数据库上查出来的
userTableModel.setUsers(Arrays.asList(new User("2", current)));
}
});
frame.getContentPane().add("South", button);
frame.setVisible(true);
}
}