JTable常见用法细则

JTable是Swing编程中很常用的控件,这里总结了一些常用方法以备查阅.欢迎补充,转载请注明作者与出处.

一.创建表格控件的各种方式:
1)  调用无参构造函数.

JTable table = new JTable();

2)  以表头和表数据创建表格.

Object[][] cellData = {{"row1-col1", "row1-col2"},{"row2-col1", "row2-col2"}};
String[] columnNames = {"col1", "col2"};
    
JTable table = new JTable(cellData, columnNames);

3)  以表头和表数据创建表格,并且让表单元格不可改.

String[] headers = { "表头一", "表头二", "表头三" };
Object[][] cellData = null;

DefaultTableModel model = new DefaultTableModel(cellData, headers) {

  public boolean isCellEditable(int row, int column) {
    return false;
  }
};

table = new JTable(model);

二.对表格列的控制
1) 设置列不可随容器组件大小变化自动调整宽度.

table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);

2) 限制某列的宽度.

);
firsetColumn.setPreferredWidth();
firsetColumn.setMaxWidth();
firsetColumn.setMinWidth();

3) 设置当前列数.

DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
;
tableModel.setColumnCount(count);

4) 取得表格列数

int cols = table.getColumnCount();

5) 添加列

DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
tableModel.addColumn("新列名");

6) 删除列

table.removeColumn(table.getColumnModel().getColumn(columnIndex));// columnIndex是要删除的列序号

三.对表格行的控制
1) 设置行高

);

2) 设置当前航数

DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
;
tableModel.setRowCount(n);

3) 取得表格行数

int rows = table.getRowCount();

4) 添加表格行

DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
tableModel.addRow(", "Boss"});

5) 删除表格行

DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
model.removeRow(rowIndex);// rowIndex是要删除的行序号

四.存取表格单元格的数据
1) 取单元格数据

DefaultTableModel tableModel = (DefaultTableModel) table.getModel();
String cellValue=(String) tableModel.getValueAt(row, column);// 取单元格数据,row是行号,column是列号

2) 填充数据到表格.
注:数据是Member类型的链表,Member类如下:

public class Member{
    // 名称
    private String name;
    
    // 年龄
    private String age;
    
    // 职务
    private String title;
}

填充数据的代码:

public void fillTable(List<Member> members){
  DefaultTableModel tableModel = (DefaultTableModel) table
  .getModel();
  tableModel.setRowCount();// 清除原有行
  
  // 填充数据
  for(Member member:members){
    String[] arr];
    arr[]=member.getName();
    arr[]=member.getAge();
    arr[]=member.getTitle();
    
    // 添加数据到表格
    tableModel.addRow(arr);
  }
  
  // 更新表格
  table.invalidate();
}

2) 取得表格中的数据

public List<Member> getShowMembers(){
  List<Member> members=new ArrayList<Member>();
  
  DefaultTableModel tableModel = (DefaultTableModel) table
  .getModel();
  
  int rowCount=tableModel.getRowCount();
  
  ;i<rowCount;i++){
    Member member=new Member();
    
    member.setName((String)tableModel.getValueAt(i, ));// 取得第i行第一列的数据
));// 取得第i行第二列的数据
));// 取得第i行第三列的数据
    
    members.add(member);
  }
  
  return members;
}

五.取得用户所选的行
1) 取得用户所选的单行

int selectRows=table.getSelectedRows().length;// 取得用户所选行的行数
DefaultTableModel tableModel = (DefaultTableModel) table.getModel();

){
  int selectedRowIndex = table.getSelectedRow(); // 取得用户所选单行  
  
  .// 进行相关处理
}

2) 取得用户所选的多行

int selectRows=table.getSelectedRows().length;// 取得用户所选行的行数
DefaultTableModel tableModel = (DefaultTableModel) table.getModel();

)
  int[] selRowIndexs=table.getSelectedRows();// 用户所选行的序列
  
  ;i<selRowIndexs.length;i++){
    // 用tableModel.getValueAt(row, column)取单元格数据
);
  }
}

六.添加表格的事件处理

view.getTable().addMouseListener(new MouseListener() {
  public void mousePressed(MouseEvent e) {
    // 鼠标按下时的处理
  }

  public void mouseReleased(MouseEvent e) {
    // 鼠标松开时的处理
  }

  public void mouseEntered(MouseEvent e) {
    // 鼠标进入表格时的处理
  }

  public void mouseExited(MouseEvent e) {
    // 鼠标退出表格时的处理
  }

  public void mouseClicked(MouseEvent e) {
    // 鼠标点击时的处理
  }
});

例子:

import java.awt.BorderLayout;
import java.awt.Dimension;
import java.awt.FlowLayout;
import java.awt.GridLayout;

import javax.swing.Icon;
import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;

public class PTest{
 
 public PTest()
 {
  String head[] = {"学号", "姓名", "成绩(请双击以下空格输入)"}; 
 
  Icon bug = new ImageIcon(getClass().getResource("789.jpg"));
  JLabel a = new JLabel (bug);

JTable a1 = new JTable (20,3);
  a1.setRowHeight (30);//设置高度
  a1.setDragEnabled(true);
 
  //设置第一、二列不可可编辑
  DefaultTableModel tableModel = new DefaultTableModel(20,3){
   boolean[] editables = {false, false, true};
   public boolean isCellEditable(int row, int col)
   {
      return editables[col];
   }

//使table不可编辑的代码(放在model中有效)全部不可编辑
//    public boolean isCellEditable(int row, int column)
//             {
//                 return false;
//             }
      }; 
      a1.setModel(tableModel);

for (int i=0; i<3; i++)
  a1.getModel().setValueAt(head[i], 0, i);

JPanel panelwrap = new JPanel (new FlowLayout ());
   JPanel panel = new JPanel (new GridLayout (2,1));
   panel.setPreferredSize (new Dimension (500,400));
   // panel.setBackground (Color.black);
   panel.add (a,BorderLayout.CENTER);
   JScrollPane a2 = new JScrollPane (a1);
   panel.add (a2,BorderLayout.CENTER);
   panelwrap.add(panel);

JFrame frame = new JFrame ("JTableDemo");
   frame.setDefaultCloseOperation (JFrame.EXIT_ON_CLOSE);
   frame.setContentPane (panelwrap);
   frame.setSize(500,400);
   frame.pack();
   frame.show();
 }
 public static void main(String[] args) {
  PTest k = new PTest();
 }
}

//////////////////////////////////////////自己的//////////////////////////////////////

private JTable getJTable0() {
  if (jTable0 == null) {
   jTable0 = new JTable();
   
   jTable0.setModel(new DefaultTableModel(new Object[][] { {false,  "null", "null", "com1", "null", "null", "null", "null", "null", "null", },
     {false, "null", "null", "com2", "null", "null", "null", "null", "null", "null",  },
     {  false, "null", "null", "com3", "null", "null", "null", "null", "null", "null",},
     { false,"null", "null", "com4", "null", "null", "null", "null", "null", "null",  },
     {  false,"null", "null", "com5", "null", "null", "null", "null", "null", "null", },
     {  false, "null", "null", "com6", "null", "null", "null", "null", "null", "null",},
     { false, "null", "null", "com7", "null", "null", "null", "null", "null", "null", },
     {false, "null", "null", "com8", "null", "null", "null", "null", "null", "null",  },
     { false,"null", "null", "com9", "null", "null", "null", "null", "null", "null", },
     { false,"null", "null", "com10", "null", "null", "null", "null", "null", "null",  },
     {false,  "null", "null", "com11", "null", "null", "null", "null", "null", "null", },
     { false, "null", "null", "com12", "null", "null", "null", "null", "null", "null", }, }, new String[] {"操作",  "ID", "status", "序号", "产品序列号", "半成品序列号",
     "所属工作任务号", "产品型号(pn码)", "生产进度状态", "端口状态", }) {
    private static final long serialVersionUID = 1L;
    Class<?>[] types = new Class<?>[] { Boolean.class, Object.class, Object.class, Object.class, Object.class, Object.class, Object.class, Object.class, Object.class,
      Object.class, };
 
    public Class<?> getColumnClass(int columnIndex) {
     return types[columnIndex];
    }
    
//    //使table不可编辑的代码(放在model中有效)全部不可编辑
//    public boolean isCellEditable(int row, int column)
//             {
//                 return false;
//             }
    //指定列不可编辑
    boolean[] editables = {true, false, false,false,false,false,false,false,false,false};
       public boolean isCellEditable(int row, int col)
       {
          return editables[col];
       }

//指定行不可编辑
    boolean[] editables = {true, false, false,false,false,false,false,false};
       public boolean isCellEditable(int row, int col)
       {
          return editables[row];
       }

});
  }
  return jTable0;
 }

JTable常见用法细则+设置某列可编辑+滚动表格的更多相关文章

  1. JTable常见用法细则

    JTable是Swing编程中很常用的控件,这里总结了一些常用方法以备查阅.欢迎补充,转载请注明作者与出处. 一.创建表格控件的各种方式:1)  调用无参构造函数. JTable table = ne ...

  2. DevExpress 控件 GridControl常见用法

    刚接触DevExpress第三方控件,把GridControl的常见用法整理一下,以供参考: 说明: gcTest   GridControl gvText    GridView //隐藏最上面的G ...

  3. GridControl常见用法【转】

    刚接触DevExpress第三方控件,把GridControl的常见用法整理一下,以供参考: 说明: gcTest   GridControl gvText    GridView //隐藏最上面的G ...

  4. php中的curl使用入门教程和常见用法实例

    摘要: [目录] php中的curl使用入门教程和常见用法实例 一.curl的优势 二.curl的简单使用步骤 三.错误处理 四.获取curl请求的具体信息 五.使用curl发送post请求 六.文件 ...

  5. iOS 开发多线程篇—GCD的常见用法

    iOS开发多线程篇—GCD的常见用法 一.延迟执行 1.介绍 iOS常见的延时执行有2种方式 (1)调用NSObject的方法 [self performSelector:@selector(run) ...

  6. iOS开发多线程篇—GCD的常见用法

    iOS开发多线程篇—GCD的常见用法 一.延迟执行 1.介绍 iOS常见的延时执行有2种方式 (1)调用NSObject的方法 [self performSelector:@selector(run) ...

  7. [HMLY]9.深入浅出-iOS Reactive Cocoa的常见用法

    简介 今天的主角是Reactive Cocoa,聊聊Reactive Cocoa的常见使用:KVO.Target.Delegate.Notification. Reactive Cocoa 是一个重量 ...

  8. Shell常见用法小记

    shell的简单使用 最近发现shell脚本在平常工作中简直算一把瑞士军刀,很多场景下用shell脚本能实现常用的简单需求,而之前都没怎么学习过shell,就趁机把shell相关的语法和常见用法总结了 ...

  9. layui(二)——layer组件常见用法总结

    layer是layui的代表作,功能十分强大,为方便以后快速配置这里对其常见用法做了简单总结 一.常用调用方式 //1.普通消息:alert(content,[options],[yesCallBac ...

随机推荐

  1. android 学习笔记(1)

    内容来源:高成珍.钟元生<Android编程经典案例>学习笔记 表格布局——TableLayout 表格布局以行和列的方式来管理界面的布局,但并不能明确声明包含几行几列.可通过TableR ...

  2. 【算法功底】LeetCode 292 Nim Game

    You are playing the following Nim Game with your friend: There is a heap of stones on the table, eac ...

  3. UTF-8 GBK UTF8 GB2312 之间的区别和关系

    UTF-8:Unicode TransformationFormat-8bit,允许含BOM,但通常不含BOM.是用以解决国际上字符的一种多字节编码,它对英文使用8位(即一个字节),中文使用24为(三 ...

  4. vim中文帮助文档安装

    vim自带的帮助手册是英文的, 对平时编程的人来说没有多大阅读困难,在何况还有"星级译王"呢, 但是我猜和我一样连英语四级都愁的大有人,可偏偏就有一帮好心人人将其翻译成了中文, 可 ...

  5. 文件系统与linux相关知识点

    文件系统是操作系统中管理持久性数据的子系统,提供数据存储和访问功能.对于服务器开发人员,比较关注的是unix(linux)环境下的文件系统,比如分区与磁盘关系,磁盘的剩余空间,文件的类型与权限控制,文 ...

  6. [编织消息框架][JAVA核心技术]动态代理应用10-水平扩展方案

    服务分为系统服务同用户服务两种 水平扩展是基于系统服务,而拆分方式又有几种方案,按数据跟业务情况来做决策 1.每个服务独立存储(图1):每个服务只负责一个或多个领域实体存储,A服务不能直接修改B服务的 ...

  7. 数据库问题(程序连接mysql错误)

    今天服务器遇到了一个很熟悉的问题 输入 #mysql -u root -p ERROR 2002 (HY000):Can't connect to local MySQL server 随即上网找寻答 ...

  8. 自己实现的string的库函数

    为了更好地理解string的各个库函数,现将几个常用的库函数用自己的方式实现如下: #include<iostream> using namespace std; #include< ...

  9. QT链接数据库

    在介绍QT与数据的链接问题上,我在这里就不介绍关于QT环境与mysql.sqlite3环境的安装步骤了,以下的所有的操作都是建立在你已经安装了所有环境的基础上的.好的,那我们就具体来看一看QT环境中怎 ...

  10. MySQL中字符串与数字比较的坑

    公司项目代码中,某枚举字段数据库表中类型是char(1),在代码中,误以为是TINYINT,所以用数字筛选,后来发现结果不对.发现了一个现象,用数字0筛选会把所有的记录给筛选出来. 经过排查发现是在M ...