闷骚的黑框眼镜 · 读懂天津学区房之南开区的学片划分和教育分析及 ...· 7 月前 · |
犯傻的菠萝 · 巴菲特逆势抄底,斥26亿美元押注流媒体派拉蒙 ...· 1 年前 · |
旅行中的硬盘 · 秘密访客影评:故弄玄虚的过家家游戏 - 哔哩哔哩· 1 年前 · |
力能扛鼎的伤疤 · EAA|一键get报赛技巧!首届艾菲汽车奖金 ...· 1 年前 · |
鬼畜的雪糕 · 柯哀亲了,《名侦探柯南》在日本卖爆了· 1 年前 · |
这是我的jTable
private JTable getJTable() {
String[] colName = { "Name", "Email", "Contact No. 1", "Contact No. 2",
"Group", "" };
if (jTable == null) {
jTable = new JTable() {
public boolean isCellEditable(int nRow, int nCol) {
return false;
DefaultTableModel contactTableModel = (DefaultTableModel) jTable
.getModel();
contactTableModel.setColumnIdentifiers(colName);
jTable.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
return jTable;
}
我将调用此方法从数据库中检索数据并将其放入表模型中
public void setUpTableData() {
DefaultTableModel tableModel = (DefaultTableModel) jTable.getModel();
ArrayList<Contact> list = new ArrayList<Contact>();
if (!con.equals(""))
list = sql.getContactListsByGroup(con);
list = sql.getContactLists();
for (int i = 0; i < list.size(); i++) {
String[] data = new String[7];
data[0] = list.get(i).getName();
data[1] = list.get(i).getEmail();
data[2] = list.get(i).getPhone1();
data[3] = list.get(i).getPhone2();
data[4] = list.get(i).getGroup();
data[5] = list.get(i).getId();
tableModel.addRow(data);
jTable.setModel(tableModel);
}
目前,我正在使用此方法在更新表数据后刷新表。我先把桌子清理一下
DefaultTableModel tableModel = (DefaultTableModel) jTable.getModel();
tableModel.setRowCount(0);
然后再次重新构造表格模型,以便刷新jTable。但我在想,有没有什么最佳实践或更好的方法来做到这一点?
我在我的Jtable中这样做,它在300ms后自动刷新;
DefaultTableModel tableModel = new DefaultTableModel(){
public boolean isCellEditable(int nRow, int nCol) {
return false;
JTable table = new JTable();
Timer t = new Timer(300, new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
addColumns();
remakeData(set);
table.setModel(model);
t.start();
private void addColumns() {
model.setColumnCount(0);
model.addColumn("NAME");
model.addColumn("EMAIL");}
private void remakeData(CollectionType< Objects > name) {
model.setRowCount(0);
for (CollectionType Objects : name){
String n = Object.getName();
String e = Object.getEmail();
model.insertRow(model.getRowCount(),new Object[] { n,e });
}}
我怀疑它是否能很好地处理像500多个这样的大量对象,唯一的方法是在你的类中实现TableModelListener,但我不知道如何很好地使用它。看看 http://download.oracle.com/javase/tutorial/uiswing/components/table.html#modelchange
使用会导致表更新的
java.util.Observable
和
java.util.Observer
不是更好吗?
对于您的案例,更快的方法是:
jTable.repaint(); // Repaint all the component (all Cells).
当一个或几个单元格发生变化时的优化方法:
((AbstractTableModel) jTable.getModel()).fireTableCellUpdated(x, 0); // Repaint one cell.
DefaultTableModel dm = (DefaultTableModel)table.getModel();
dm.fireTableDataChanged(); // notifies the JTable that the model has changed
尝尝这个
public void setUpTableData() {
DefaultTableModel tableModel = (DefaultTableModel) jTable.getModel();
* additional code.
tableModel.setRowCount(0);
ArrayList<Contact> list = new ArrayList<Contact>();
if (!con.equals(""))
list = sql.getContactListsByGroup(con);
list = sql.getContactLists();
for (int i = 0; i < list.size(); i++) {
String[] data = new String[7];
data[0] = list.get(i).getName();
data[1] = list.get(i).getEmail();
data[2] = list.get(i).getPhone1();
data[3] = list.get(i).getPhone2();
data[4] = list.get(i).getGroup();
data[5] = list.get(i).getId();
tableModel.addRow(data);
jTable.setModel(tableModel);