JavaFX+Jfoenix 学习笔记(三)--TableView数据表格

1、我为什么把TableView叫做数据表格

答:作为JavaWeb出身离不开数据表格的支持,比如JqGrid(叫表格控件的更准确些吧,但我习惯叫它数据表格),

在Web端通常用来将一个集合的数据用表格的形式展现出来,TableView做的也是这样的事情。

2、JavaFX的数据表格跟Web端的数据表格有什么不同吗

答:没有(或者说我用的简单没发现不同),所以如果你了解Web端的数据表格,那么TableViewh核心思想你以知晓。

3、Jfoenix有重写TableView吗

答:并没有,如果有的话我想我会优先考虑的,但其实JavaFX的TableView已经够用了,实在不行自己也可以重写。

       多说一句:Jfoenbix有重写TreeTableView(树结构数据表格),叫做JFXTreeTableView(标准的Jfoenix组件命名方式JFX打头)。

 

如果说了半天你还是不知道什么是数据表格,那么说明你刚入行吧,请看下面的案例

 

4、实例-1:最简单的TableView演示

package zkh.javafx.learn.tableview;

import javafx.application.Application;
import javafx.beans.property.SimpleStringProperty;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.scene.Scene;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
import javafx.scene.control.cell.PropertyValueFactory;
import javafx.scene.control.cell.TextFieldTableCell;
import javafx.scene.image.Image;
import javafx.stage.Stage;
import zkh.javafx.util.Constants;

/**
 * TableView
 */
//继承javafx.application.Application是JavaFX的开始
public class TableView1 extends Application {
 
	// 我们的主角--数据表格
    private TableView<Person> table = new TableView<Person>();
    // 我们的配角--数据
    private ObservableList<Person> data = FXCollections.observableArrayList(
    		new Person("1", "张三"),
    		new Person("2", "李四"),
    		new Person("3", "王五")
    );
 
    @SuppressWarnings({ "rawtypes", "unchecked" })
	@Override
    public void start(Stage stage) {
    	// (如果需要的话)定位横纵坐标,避免太靠边上遮盖菜单栏,,这两行如果不屑,一般电脑默认是居中屏幕显示,但在有些电脑会跑偏
        // stage.setX(0);stage.setY(4);
        // stage和Scene不再注释
  	    stage.setTitle(Constants.TITLE);
  	    stage.getIcons().add(new Image(Constants.IMG + "icon.png"));
      
        // 下面才是本章需要关注的代码======================================================================
        // 我们创建一个两列的数据表格
        // 创建第一列,列名叫ID
        TableColumn idColumn = new TableColumn("ID");
        // (很有用),指定该列可编辑(你双击后会显示文本框,修改后回车(Enter)保存)
        idColumn.setCellFactory(TextFieldTableCell.forTableColumn());
        // 设置列的最小宽度(列的宽度只能设置首选宽度或最小宽度)
        idColumn.setMinWidth(100);
        // 指定第一列显示Person对象id属性的值
        idColumn.setCellValueFactory(new PropertyValueFactory<Object, Object>("id"));

        // 创建第二列,列名叫NAME
        TableColumn nameColumn = new TableColumn("NAME");
        // 设置列的最小宽度(列的宽度只能设置首选宽度或最小宽度)
        nameColumn.setMinWidth(200);
        // 指定第二列显示Person对象name属性的值
        nameColumn.setCellValueFactory(new PropertyValueFactory<Object, Object>("name"));

        // 将数据存入数据列表
        table.setItems(data);
        // 将我们创建的列添加进数据表格
        table.getColumns().addAll(idColumn, nameColumn);
        // 设置可编辑(列需要同时设置才有用)
        table.setEditable(true);
        // (很有用)宽度绑定窗口的宽度(意思窗口大小改变,它也跟着改变,自适应效果)
        table.prefWidthProperty().bind(stage.widthProperty());

        // 1、初始化一个场景
	    Scene scene = new Scene(table, 800, 600);
	    // 2、将场景放入窗口
	    stage.setScene(scene);
	    // 
  • 6
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值