sitinspring原创,转载请注明作者及出处.
JTable是Swing编程中很常用的控件,这里总结了一些常用方法以备查阅.欢迎补充,转载请注明作者与出处.
一.创建表格控件的各种方式
:
1)
调用无参构造函数
.
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
JTable table =
new JTable();
2)
以表头和表数据创建表格
.
![](https://i-blog.csdnimg.cn/blog_migrate/1fa987a29c6482f53d401256f96355eb.gif)
Object[][] cellData =
{{"row1-col1", "row1-col2"},{"row2-col1", "row2-col2"}};
![](https://i-blog.csdnimg.cn/blog_migrate/1fa987a29c6482f53d401256f96355eb.gif)
String[] columnNames =
{"col1", "col2"};
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
JTable table =
new JTable(cellData, columnNames);
3)
以表头和表数据创建表格,并且让表单元格不可改
.
![](https://i-blog.csdnimg.cn/blog_migrate/1fa987a29c6482f53d401256f96355eb.gif)
String[] headers =
{ "表头一", "表头二", "表头三" };
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
Object[][] cellData =
null;
![](https://i-blog.csdnimg.cn/blog_migrate/1fa987a29c6482f53d401256f96355eb.gif)
DefaultTableModel model =
new DefaultTableModel(cellData, headers)
{
![](https://i-blog.csdnimg.cn/blog_migrate/d18c02628675d0a2c816449d98bda930.gif)
public boolean isCellEditable(int row, int column) {
return false;
}
};
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
table =
new JTable(model);
二.对表格列的控制
1) 设置列不可随容器组件大小变化自动调整宽度.
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
2) 限制某列的宽度.
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
TableColumn firsetColumn = table.getColumnModel().getColumn(0);
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
firsetColumn.setPreferredWidth(30);
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
firsetColumn.setMaxWidth(30);
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
firsetColumn.setMinWidth(30);
3) 设置当前列数.
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
int count=5;
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
tableModel.setColumnCount(count);
4) 取得表格列数
int cols = table.getColumnCount();
5) 添加列
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
tableModel.addColumn("新列名");
6) 删除列
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
table.removeColumn(table.getColumnModel().getColumn(columnIndex));
//
columnIndex是要删除的列序号
三.对表格行的控制
1) 设置行高
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
table.setRowHeight(20);
2) 设置当前航数
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
int n=5;
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
tableModel.setRowCount(n);
3) 取得表格行数
int rows = table.getRowCount();
4) 添加表格行
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
![](https://i-blog.csdnimg.cn/blog_migrate/1fa987a29c6482f53d401256f96355eb.gif)
tableModel.addRow(
new Object[]
{"sitinspring", "35", "Boss"});
5) 删除表格行
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
model.removeRow(rowIndex);
//
rowIndex是要删除的行序号
四.存取表格单元格的数据
1) 取单元格数据
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
![](https://i-blog.csdnimg.cn/blog_migrate/4f1150b881333f12a311ae9ef34da474.gif)
String cellValue=(String) tableModel.getValueAt(row, column);
//
取单元格数据,row是行号,column是列号
2) 填充数据到表格.
注:数据是Member类型的链表,Member类如下:
填充数据的代码
:
2) 取得表格中的数据
五.取得用户所选的行
1) 取得用户所选的单行
2) 取得用户所选的多行
六.添加表格的事件处理