分享中的代码,大多是借鉴或者直接从别人源码中拿过来的,大家一起分享下。
在表中实现数据过滤,他的代码很简单。有2个datalist,一个用于保存原始数据,另一个实时数据。监听text里面内容,每次从原始数据中获得想要的数据放入实时中。
package customUI.filterDataInTable;
import java.io.IOException;
import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Scene;
import javafx.scene.layout.AnchorPane;
import javafx.stage.Stage;
public class MainApp extends Application {
@Override
public void start(Stage primaryStage) {
primaryStage.setTitle("Table Filtering");
try {
FXMLLoader loader = new FXMLLoader(MainApp.class.getResource("PersonTable.fxml"));
AnchorPane page = (AnchorPane) loader.load();
Scene scene = new Scene(page);
primaryStage.setScene(scene);
primaryStage.show();
} catch (IOException e) {
System.err.println("Error loading PersonTable.fxml!");
e.printStackTrace();
}
}
public static void main(String[] args) {
launch(args);
}
}
<?xml version="1.0" encoding="UTF-8"?>
<?import java.lang.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.layout.AnchorPane?>
<?import jfxtras.labs.scene.control.*?>
<AnchorPane minWidth="315.0" prefHeight="300.0" prefWidth="315.0" xmlns:fx="http://javafx.com/fxml" fx:controller="customUI.filterDataInTable.PersonTableController">
<children>
<TableView fx:id="personTable" prefHeight="-1.0" prefWidth="-1.0" tableMenuButtonVisible="false" AnchorPane.bottomAnchor="10.0" AnchorPane.leftAnchor="10.0" AnchorPane.rightAnchor="10.0" AnchorPane.topAnchor="40.0">
<columns>
<TableColumn maxWidth="5000.0" minWidth="10.0" prefWidth="120.0" text="First Name" fx:id="firstNameColumn" />
<TableColumn maxWidth="5000.0" minWidth="10.0" prefWidth="120.0" text="Last Name" fx:id="lastNameColumn" />
</columns>
</TableView>
<HBox id="HBox" alignment="CENTER" spacing="5.0" AnchorPane.leftAnchor="10.0" AnchorPane.rightAnchor="10.0" AnchorPane.topAnchor="10.0">
<children>
<Label text="Filter Table:" />
<TextField fx:id="filterField" prefWidth="-1.0" HBox.hgrow="ALWAYS" />
</children>
</HBox>
</children>
</AnchorPane>
package customUI.filterDataInTable;
public class Person {
private String firstName;
private String lastName;
public Person(String firstName, String lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
}
package customUI.filterDataInTable;
import java.util.ArrayList;
import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;
import javafx.collections.FXCollections;
import javafx.collections.ListChangeListener;
import javafx.collections.ObservableList;
import javafx.fxml.FXML;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
import javafx.scene.control.TextField;
import javafx.scene.control.cell.PropertyValueFactory;
public class PersonTableController {
@FXML
private TextField filterField;
@FXML
private TableView<Person> personTable;
@FXML
private TableColumn<Person, String> firstNameColumn;
@FXML
private TableColumn<Person, String> lastNameColumn;
private ObservableList<Person> masterData = FXCollections.observableArrayList();
private ObservableList<Person> filteredData = FXCollections.observableArrayList();
/**
* The constructor. The constructor is called before the initialize()
* method.
*/
public PersonTableController() {
// Add some sample data to the master data
masterData.add(new Person("Hans", "Muster"));
masterData.add(new Person("Ruth", "Mueller"));
masterData.add(new Person("Heinz", "Kurz"));
masterData.add(new Person("Cornelia", "Meier"));
masterData.add(new Person("Werner", "Meyer"));
masterData.add(new Person("Lydia", "Kunz"));
masterData.add(new Person("Anna", "Best"));
masterData.add(new Person("Stefan", "Meier"));
masterData.add(new Person("Martin", "Mueller"));
// Initially add all data to filtered data
filteredData.addAll(masterData);
// Listen for changes in master data.
// Whenever the master data changes we must also update the filtered data.
masterData.addListener(new ListChangeListener<Person>() {
@Override
public void onChanged(ListChangeListener.Change<? extends Person> change) {
updateFilteredData();
}
});
}
/**
* Initializes the controller class. This method is automatically called
* after the fxml file has been loaded.
*/
@FXML
private void initialize() {
// Initialize the person table
firstNameColumn.setCellValueFactory(
new PropertyValueFactory<Person, String>("firstName"));
lastNameColumn.setCellValueFactory(
new PropertyValueFactory<Person, String>("lastName"));
// Add filtered data to the table
personTable.setItems(filteredData);
// Listen for text changes in the filter text field
filterField.textProperty().addListener(new ChangeListener<String>() {
@Override
public void changed(ObservableValue<? extends String> observable,
String oldValue, String newValue) {
updateFilteredData();
}
});
}
/**
* Updates the filteredData to contain all data from the masterData that
* matches the current filter.
*/
private void updateFilteredData() {
filteredData.clear();
for (Person p : masterData) {
if (matchesFilter(p)) {
filteredData.add(p);
}
}
// Must re-sort table after items changed
reapplyTableSortOrder();
}
/**
* Returns true if the person matches the current filter. Lower/Upper case
* is ignored.
*
* @param person
* @return
*/
private boolean matchesFilter(Person person) {
String filterString = filterField.getText();
if (filterString == null || filterString.isEmpty()) {
// No filter --> Add all.
return true;
}
String lowerCaseFilterString = filterString.toLowerCase();
if (person.getFirstName().toLowerCase().indexOf(lowerCaseFilterString) != -1) {
return true;
} else if (person.getLastName().toLowerCase().indexOf(lowerCaseFilterString) != -1) {
return true;
}
return false; // Does not match
}
private void reapplyTableSortOrder() {
ArrayList<TableColumn<Person, ?>> sortOrder = new ArrayList(personTable.getSortOrder());
personTable.getSortOrder().clear();
personTable.getSortOrder().addAll(sortOrder);
}
}
分享到:
相关推荐
在"JavaFX+Jfoenix 学习笔记(三)--TableView数据表格源码"中,我们将重点讨论如何使用JavaFX的TableView组件结合JFoenix来展示和操作数据。TableView是JavaFX中的一个核心组件,它允许用户以表格的形式查看和操作...
在JavaFX中,TableView是一个强大的组件,用于展示和操作数据集。这个教程或者项目"基于JavaFx TableView的人员增删查改界面"旨在教你如何利用JavaFX构建一个用户界面,该界面可以对人员数据进行基本的操作,如添加...
在JavaFX中,表格是一种强大的可视化组件,用于展示和操作数据。这个压缩包包含了一些关键的源码文件,如`CustomerTable.fx`、`Cell.fx`和`HeaderCell.fx`,它们是构建JavaFX表格应用的核心部分。让我们深入探讨这些...
总之,这个"javafx 2.0 tableview 实例"涵盖了JavaFX中数据展示的核心部分,是学习和理解TableView功能的好起点。开发者可以通过这个实例深入理解如何在JavaFX应用中处理和展示数据,为构建功能丰富的用户界面打下...
在JavaFX 2.0版本中,`TableView`是一个核心的组件,用于展示结构化的数据集,类似于传统的电子表格。下面我们将深入探讨`TableView`的使用方法,包括数据列的绑定。 `TableView`是JavaFX中的一个视图类,它允许...
这些控件通常具有灵活的功能,如数据排序、过滤、搜索,以及本例中提到的行删除和列合并。在Web开发中,常见的表格控件有HTML `<table>` 标签、JavaScript 库如 jQuery DataTables、Angular Material 的 MatTable,...
通过本文档的学习,我们了解了 JavaFX UI 控件的基本使用方法。掌握了这些控件之后,你可以根据实际项目需求灵活地构建各种类型的用户界面。无论是简单的应用还是复杂的商业系统,JavaFX 都能提供所需的功能和支持,...
在计算机用户界面设计中,TreeTable结合了表格(Table)和树视图(TreeView)的优点,为用户提供了一种高效且直观的方式来浏览层次化数据。这种控件在诸如项目管理、文件系统浏览、数据库查询结果展示等多个场景中都...
在Java开发中,表格(Table)的展示是常见的需求,特别是在数据管理、数据分析以及用户界面设计中。"快速进行JAVA_Table开发的表格"提供了一种高效的方法来实现这一功能,尤其适合初学者学习和测试。这个资源可能...
在JavaFX中,TableView是一个强大的组件,用于展示结构化数据的列表。`TableViewSample`是一个典型的例子,展示了如何使用JavaFX绑定数据到TableView控件,从而实现数据的动态展示和交互。在这个项目中,我们主要...
3. **易于集成**:由于是用Java编写的,它可以无缝集成到Java应用程序中,与Java Swing或JavaFX等图形用户界面库配合良好。 4. **强大的数据操作**:提供丰富的API用于数据的添加、删除、修改和查询,支持条件过滤...
### 如何在JavaFX TableView中实现过滤功能 在JavaFX应用程序中,`TableView`是非常常用的一个组件,用于展示数据表格。对于需要用户交互的应用场景,如动态筛选数据、排序等功能非常实用。本篇将详细介绍如何在...
在Java Swing或JavaFX中,TABLE组件允许用户以表格形式查看和操作数据,便于数据的分类、排序和过滤。通过自定义模型,开发者可以轻松地将数据库中的信息映射到表格中,使得用户能够直观地查看和管理人事及财务信息...
7. **运行TableDemo**:在MyEclipse中,运行TableDemo类,你会看到一个包含预设数据的简单表格出现在屏幕上。 这个过程虽然简略,但涵盖了基本的表格创建步骤。更复杂的表格功能,如排序、过滤、编辑等,需要进一步...
它提供了丰富的功能,如分页、排序、过滤、行选择等,使得在Web应用中创建数据表变得简单。 5. **Model-View-Controller (MVC)**: 数据表组件通常遵循MVC设计模式,其中模型负责管理数据,视图负责显示数据,控制...
SQL语句的编写需要对SQL语法有深入理解,例如,WHERE子句用于指定条件,JOIN用于合并多表数据,GROUP BY和HAVING用于分组和过滤等。 在执行SQL语句时,我们通常使用Statement或PreparedStatement接口。...
TreeTableView是一种特殊的用户界面元素,常见于图形用户界面(GUI)应用中,特别是在JavaFX或Swing等开发框架中。它结合了树视图(TreeView)和表格视图(TableView)的功能,允许用户同时以层次结构和表格的形式...
这些特性在数据库操作中起到了关键作用,特别是在数据过滤、排序和聚合等方面。 3. **SQLite**: SQLite是一款轻量级的嵌入式数据库,无需单独的服务器进程即可运行,适合于小型应用或者作为开发阶段的临时数据库。...
在Java中,我们可以使用Swing或JavaFX等库来创建GUI(图形用户界面),显示数据。TableFrame可能就是一个使用JTable或TableView组件来展示SQL查询结果的类。JTable是Swing的一部分,可以方便地将数据模型与表格视图...
例如,`SimpleTable.java`可能实现了基本的表格功能,而`DHTable.java`可能是在此基础上增加了排序、过滤等高级特性。 `myframe.java`可能代表了系统的主界面框架,使用了Java Swing或JavaFX库来创建图形用户界面...