JavaFX TableView和ListView的点击事件

article/2025/8/26 11:35:25

项目场景:

最近在用JavaFX做一个简易的商城界面,大概想实现这样的功能: 

  1. 左边显示用户的最近五个购买的产品 使用ListView
    1. 点击ListView的项目会定位到相应的tablerow位置 方便用户快速查找
  2. 中间显示所有可用产品 使用TableView
    1. 双击tablerow的Item将弹出alert 询问用户购买数量
  3. 右边是Filter 根据filter将tableview实时分类

问题描述

如何生成一个正确的tableview呢?

public TableView<Item> table= new TableView<>();

在使用 table.setItems(data) 给table传值之前,我们需要给data设置好格式, 常用格式是

private final ObservableList<Item> data =FXCollections.observableArrayList();

紧接着,去给每个tableview中的column设置好cellvalue的映射

nameColumn.setCellValueFactory(new PropertyValueFactory("name"));

这里的名字需要Item类中需要有例如public String getName()来对应。

表中有了数据,如何给tableview设置点击事件 - 双击row弹出窗口?

// table row 点击事件
table.setRowFactory( tv -> {TableRow<Item> row = new TableRow<>();row.setOnMouseClicked(event -> {// 点击两次 且 row不为空if (event.getClickCount() == 2 && (! row.isEmpty()) ) {Item itemInfo = row.getItem();// 点击以后的事件System.out.println(itemInfo.getName());Alert alert = new Alert(Alert.AlertType.CONFIRMATION);alert.setTitle(null);alert.setContentText("你想将” + itemInfo.getName() +“加入购物车吗?");Optional<ButtonType> result = alert.showAndWait();// if (result.get().equals(ButtonType.OK)...之类的}});return row ;
});

好了现在加入购物车功能完成了

ListView跟tableview逻辑差不多而且更简单,一个for循环遍历将String加进去List,最后list.setItems(你的list) 就完事了。

重点来了 要如何在点击ListView的时候 聚焦Tableview的内容?

苦苦找了很久 没有人讲 只能去翻oracle的doc了 文档在这里

TableView.TableViewFocusModel (JavaFX 8)

翻完发现我要的就是他的成员方法 focus() !那要怎么使用呢?

很简单 不需要去新建一个TableViewFocusModel了 直接用现有的 table.getFocusModel.focus(index) 就能直接使用

好了来看看代码吧

Solution 1

找到table中的index以后 使用

table.requestFocus();
table.getFocusModel().focus(i);

效果是这样

Solution 2 (我采取的方案)

list.getSelectionModel().selectedItemProperty().addListener((ObservableValue<? extends String> ov,String old_val, String new_val) -> {for (int i=0; i<data.size(); i++){if (data.get(i).getName().equals(new_val)){// table.requestFocus();// table.getFocusModel().focus(i);table.getSelectionModel().select(i);table.scrollTo(i);System.out.println(i);}}});

此处的table.scrollTo(i) 是很重要的 否则聚焦了在下面的产品 用户也看不到

最后剩下Filter怎么办呢 更简单 换成一个FilteredList就搞定了。

// category 筛选事件
category.setOnAction( (event -> {categoryChosen = (String) category.getValue();filteredList =new FilteredList<>(data, t -> {if (categoryChosen.equals("All")){return true;} else return t.getCategory().equals(categoryChosen);});table.setItems(filteredList);
}));

完美实现所有功能 使用这个古老的语言真是麻烦 网上都没什么教程 找来找去只能看英文的文档 那就写份中文的记录一下吧。这次还实现了很多很酷的功能 但是懒得记了。


http://chatgpt.dhexx.cn/article/piUOdqhB.shtml

相关文章

JavaFX【TableView使用详解】

目录 概述 组件 Student ObservableList TableView setCellValueFactory() TableColumn 1. Callback 2. PropertyValueFactory 增加到末行 1、tableView.getItems().add(Student s) 2、list.add(Student s) 删除指定行 1、tableView.getItems().remove(int i) 2、…

QT中TableView数据展示

QT中TableView数据展示 最近在学习QT,大量数据从数据库取出放入QT界面中展示&#xff0c;这时用到了tableView&#xff0c;一些简单的使用分享给大家。 创建数据模型 QStandardItemModel *modelnew QStandardItemModel(); QStandardItemModel是Qt库中的一个类&#xff0c;它…

JAVAFX的TableView基本用法

JAVAFX中的表格显示主要使用TableView 与TableView相关的类: TableColumn TableRow TableCell TablePosition TableViewFocusModel TableViewSelectionModel JavaFX TableView例子: import javafx.application.Application; import javafx.scene.Scene; import javafx.scene…

QT之Tableview

想要了解更多的tableview可以看这位博客Qt深入浅出&#xff08;十五&#xff09;QTableView​ 这里做了一个简单的学生系统查询功能显示Tableview&#xff1a; 表格视图控件QTableView&#xff0c;需要和QStandardItemModel, 配套使用&#xff0c;这套框架是基于MVC设计模式设…

QML TableView 使用详解

目录 一、—个简单的TableView实例 二、TableViewColumn 属性讲解 三、定制表格外观 3.1 itemDelegate3.2 rowDelegate3.3 headerDelegate3.4 定制表格外观后的示例 四、动态增删改查 TabelView TableView 就是 Qt Quick 为表格式呈现数据提供的组件。想必兄台用过 Excel…

QT控件之(TableView)的居中效果

T将tableView中的表头以及文本内容都进行居中处理 1、需要在构造函数中增加一句&#xff1a; //以下增加的是表头的效果 ui->tableView->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);//布局排版是全部伸展开的效果2、就是直接对tableView的文本内…

QML学习十七:TableView的简单使用

若该文为原创文章&#xff0c;转载请注明原文出处 一、TableView TableView是Qt Quick为表格式呈现数据提供的组件。 TableView与ListView类似&#xff0c;相比之下多了滚动条、挑选、可调整尺寸的表头等特性&#xff0c;数据也是通过Model来提供&#xff0c;此篇使用的是内建…

JavaFX中TableView的使用

稍微说说JavaFX里面TableView怎么用&#xff0c;&#xff08;其实在JavaFX的源码中都有示例。。。&#xff09; 首先要了解TableView是用来做什么的&#xff0c;TableView是JavaFX的一个表视图&#xff0c;用来显示表格的&#xff0c;在TableView的类注释中写了 /*** see Tab…

Qt4实现TableView显示表格数据

最近又开始搞QT开发了&#xff0c;前面学的MVC啥的都忘得差不多了&#xff0c;重新整理一遍思路吧。 目前的需求是&#xff1a;读取文本文件&#xff0c;表格型数据&#xff0c;用tableview显示出来&#xff0c;最后画图。这涉及到三个问题&#xff0c;文件读写&#xff0c;数…

NAT模式下的虚拟机网络配置

原理 NAT模式&#xff0c;也叫地址转换模式&#xff0c; 当把我们的虚拟机的上网方式设置为NAT模式时&#xff0c;虚拟机、宿主机、各网卡之间的连接关系可用下图来表示&#xff1a; 具体配置流程 1 将本地以太网共享到v8适配器上 2 查看虚拟网络编辑中的NAT模式下的子网IP…

虚拟机vmware设置nat模式上网

桥接模式上网&#xff1a;虚拟机vmware设置桥接模式上网_cao849861802的博客-CSDN博客 首先虚拟机有两个虚拟网卡vmnet0和vmnet8 这个vmnet0默认的是桥接模式&#xff0c;这个vmnet8默认是nat模式&#xff1b; 我们这里只看nat模式&#xff0c;所以先不关心vmnet0虚拟网卡&a…

VMware16NAT模式配置固定IP

文章目录 前言一、NAT配置固定IP二、重启网卡结尾 前言 为什么要配置固定IP呀&#xff1f;这个很容易解释啊&#xff0c;因为配置集群要设置固定IP&#xff08;主结点需要管理子结点&#xff0c;通过固定IP识别机器&#xff09;&#xff0c;因为你访问虚拟机方便&#xff08;不…

VMware Workstation中桥接模式、NAT模式、仅主机模式

一、VMware虚拟机的网络模式 VMware工作站虚拟机有三种网络模式【①桥接模式 ②NAT模式 ③仅主机模式】,如下图所示: 二、VMware虚拟机的网络模式介绍 2.0、VMware的虚拟设备 VMware的虚拟设备 序号虚拟设备编号说明1VMnet0是虚拟桥接网络下的虚拟交换机2VMnet1是虚拟Host-…

vm虚拟机nat模式配置

痛点&#xff1a; 为了解决虚拟机与板子网络的调试的问题&#xff0c;我之前一直用桥接&#xff0c;如果虚拟机想上网就桥接到无线网卡&#xff0c;如果想连接板子&#xff0c;就桥接到有线网卡&#xff0c;麻烦&#xff0c;需要来回切换&#xff0c;还有就是不插板子的情况下和…

nat模式

原文链接&#xff1a;https://www.linuxidc.com/Linux/2016-09/135521p2.htm &#xff08;复制过来只是为了学习方便&#xff0c;如有不妥会立即删除&#xff09; 二、NAT&#xff08;地址转换模式&#xff09; 刚刚我们说到&#xff0c;如果你的网络ip资源紧缺&#xff0c;但…

虚拟机NAT模式无法联网

工作中遇到NAT模式虚拟机&#xff0c;修改了编辑-虚拟网络编辑器 中NAT设置IP&#xff0c;DNS&#xff0c;DHCP等配置&#xff0c;在centos8中修改了ens33文件都无法联网的情况&#xff0c;特此总结解决方案 按照该方法尝试后无效&#xff08;解决方法在下面&#xff09; 第一…

桥接模式NAT模式 详解

NAT模式 和 桥接模式 网络地址转换 NAT &#xff1a; 首先看一下NAT的概念&#xff1a;装有NAT软件的路由器叫做NAT路由器&#xff0c;它至少有一个有效的外部全球IP地址&#xff0c;这样所有使用本地地址&#xff08;内部专用地址&#xff09;的主机在和外界通信时&#xff…

虚拟机NAT模式无法上网

虚拟机NAT模式无法上网 一、确认虚拟机的ip地址二、确认服务是否开启 一、确认虚拟机的ip地址 确认虚拟机的ip地址与本机的vmnet8的ip地址是否在同一个网段&#xff0c;且网关是否一致&#xff1a; cd /etc/sysconfig/network-scripts/ ls vi ifcfg-ens33如果ip配置都没有问…

【VMware】NAT模式、桥接模式、仅主机模式

VMware的NAT模式、桥接模式、仅主机模式 转载自&#xff1a;https://wxler.github.io/2021/02/02/221724/ 1. NAT模式 拓扑图&#xff1a; 在NAT网络中&#xff0c;会用到VMware Network AdepterVMnet8虚拟网卡。 VMware Network AdepterVMnet8是主机上的一块虚拟网卡&…

虚拟机NAT模式集群改为桥接模式集群

有时候&#xff0c;A 电脑要访问 B 电脑上安装的虚拟机&#xff0c;尴尬的是之前虚拟机配置的网络连接模式为 NAT 模式。 那怎么才能让 A 电脑正常地访问 B 电脑上的虚拟机呢&#xff1f;就需要将虚拟机的网络连接模式由 NAT 模式修改为 桥接模式 。 需要下面简单的几步就可以…