Java表格JTable代码实例解析

 更新时间:2020年03月16日 12:31:54   作者:rainbow70626  
这篇文章主要介绍了Java表格JTable代码实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

代码如下:

import javax.swing.JTable;
import javax.swing.table.AbstractTableModel;
import javax.swing.JScrollPane;
import javax.swing.JFrame;
import javax.swing.JOptionPane;
import java.awt.*;
import java.awt.event.*;

public class JTableDemo extends JFrame {
  private boolean DEBUG = true;

  public JTableDemo() { // 实现构造方法
    super("RecorderOfWorkers"); // 首先调用父类JFrame的构造方法生成一个窗口
    MyTableModel myModel = new MyTableModel();// myModel存放表格的数据
    JTable table = new JTable(myModel);// 表格对象table的数据来源是myModel对象
    table.setPreferredScrollableViewportSize(new Dimension(500, 70));// 表格的显示尺寸

    // 产生一个带滚动条的面板
    JScrollPane scrollPane = new JScrollPane(table);

    // 将带滚动条的面板添加入窗口中
    getContentPane().add(scrollPane, BorderLayout.CENTER);

    addWindowListener(new WindowAdapter() {// 注册窗口监听器
      public void windowClosing(WindowEvent e) {
        System.exit(0);
      }
    });
  }

  // 把要显示在表格中的数据存入字符串数组和Object数组中
  class MyTableModel extends AbstractTableModel {
    // 表格中第一行所要显示的内容存放在字符串数组columnNames中
    final String[] columnNames = { "First Name", "Position", "Telephone",
        "MonthlyPay", "Married" };
    // 表格中各行的内容保存在二维数组data中
    final Object[][] data = {
        { "Wangdong", "Executive", "01068790231", new Integer(5000),
            new Boolean(false) },
        { "LiHong", "Secretary", "01069785321", new Integer(3500),
            new Boolean(true) },
        { "LiRui", "Manager", "01065498732", new Integer(4500),
            new Boolean(false) },
        { "ZhaoXin", "Safeguard", "01062796879", new Integer(2000),
            new Boolean(true) },
        { "ChenLei", "Salesman", "01063541298", new Integer(4000),
            new Boolean(false) } };

    // 下述方法是重写AbstractTableModel中的方法,其主要用途是被JTable对象调用,以便在表格中正确的显示出来。程序员必须根据采用的数据类型加以恰当实现。

    // 获得列的数目
    public int getColumnCount() {
      return columnNames.length;
    }

    // 获得行的数目
    public int getRowCount() {
      return data.length;
    }

    // 获得某列的名字,而目前各列的名字保存在字符串数组columnNames中
    public String getColumnName(int col) {
      return columnNames[col];
    }

    // 获得某行某列的数据,而数据保存在对象数组data中
    public Object getValueAt(int row, int col) {
      return data[row][col];
    }

    // 判断每个单元格的类型
    public Class getColumnClass(int c) {
      return getValueAt(0, c).getClass();
    }

    // 将表格声明为可编辑的
    public boolean isCellEditable(int row, int col) {

      if (col < 2) {
        return false;
      } else {
        return true;
      }
    }

    // 改变某个数据的值
    public void setValueAt(Object value, int row, int col) {
      if (DEBUG) {
        System.out.println("Setting value at " + row + "," + col
            + " to " + value + " (an instance of "
            + value.getClass() + ")");
      }

      if (data[0][col] instanceof Integer && !(value instanceof Integer)) {
        try {
          data[row][col] = new Integer(value.toString());
          fireTableCellUpdated(row, col);
        } catch (NumberFormatException e) {
          JOptionPane.showMessageDialog(JTableDemo.this, "The \""
              + getColumnName(col)
              + "\" column accepts only integer values.");
        }
      } else {
        data[row][col] = value;
        fireTableCellUpdated(row, col);
      }

      if (DEBUG) {
        System.out.println("New value of data:");
        printDebugData();
      }
    }

    private void printDebugData() {
      int numRows = getRowCount();
      int numCols = getColumnCount();

      for (int i = 0; i < numRows; i++) {
        System.out.print(" row " + i + ":");
        for (int j = 0; j < numCols; j++) {
          System.out.print(" " + data[i][j]);
        }
        System.out.println();
      }
      System.out.println("--------------------------");
    }
  }

  public static void main(String[] args) {
    JTableDemo frame = new JTableDemo();
    frame.pack();
    frame.setVisible(true);
  }
}

代码运行效果截图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • JDBC连接MySQL并实现模糊查询

    JDBC连接MySQL并实现模糊查询

    本文详细讲解了JDBC连接MySQL并实现模糊查询的方式,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-01-01
  • springBoot集成redis(jedis)的实现示例

    springBoot集成redis(jedis)的实现示例

    Redis是我们Java开发中,使用频次非常高的一个nosql数据库,本文主要介绍了springBoot集成redis(jedis)的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-09-09
  • Netty分布式客户端接入流程初始化源码分析

    Netty分布式客户端接入流程初始化源码分析

    这篇文章主要介绍了Netty分布式客户端接入流程初始化源码分析,有关channelConfig有关的初始化过程剖析,有需要的朋友可以借鉴参考下,希望能够有所帮助
    2022-03-03
  • Token登陆验证机制的原理及实现

    Token登陆验证机制的原理及实现

    这篇文章介绍了Token登陆验证机制的原理及实现,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-12-12
  • Java保留两位小数的几种写法总结

    Java保留两位小数的几种写法总结

    相信大家在平时做项目时,可能会有这样的业务需求: 页面或界面上展示的数据保留小数点后两位。 那么这篇文章小编就和大家分享了利用Java保留两位小数的几种写法,文章给出了详细的示例代码,对大家的学习和理解很有帮助,有需要的朋友们下面来一起学习学习下吧。
    2016-11-11
  • SpringCloud Bus消息总线的实现

    SpringCloud Bus消息总线的实现

    消息总线是一种通信工具,可以在机器之间互相传输消息、文件等,这篇文章主要介绍了SpringCloud Bus消息总线的实现,Spring cloud bus 通过轻量消息代理连接各个分布的节点,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • MyBatis一级缓存避坑完全指南

    MyBatis一级缓存避坑完全指南

    这篇文章主要给大家介绍了关于MyBatis一级缓存避坑的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • 解决mybatis映射mapper.xml文件不编译的问题

    解决mybatis映射mapper.xml文件不编译的问题

    这篇文章主要介绍了解决mybatis映射mapper.xml文件不编译的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • SpringBoot集成多数据源解析

    SpringBoot集成多数据源解析

    这篇文章主要介绍了SpringBoot集成多数据源解析,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • 如何使用BigDecimal实现Java开发商业计算

    如何使用BigDecimal实现Java开发商业计算

    这篇文章主要介绍了如何使用BigDecimal实现Java开发商业计算,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09

最新评论