amr*_*mru 5 java javafx tableview
我的TableView填充数据库中的数据。当用户单击列标题时,它会根据它对数据进行排序。此功能是开箱即用的。但是,我有太多记录无法一次填充它们。假设我有1000条记录,并且该表仅显示500条。按列对它进行排序时,它仅会使500条已经填充的记录变短。
我想覆盖排序行为,以便当用户单击列标题时,它将从数据库中重新加载数据并为查询中的“ order by”子句提供必要的信息。我的问题是,我不知道
我得到了一个丑陋的解决方案,只能解决问题的一半。我可以将侦听器附加到列标题单击事件,但无法删除默认的 TableView 排序行为。
private void initTable() {
...
...
//listen to sorting type (ASC/DESC) change
SortTypeChangeListener sortTypeChangeListener = new SortTypeChangeListener();
clmName.sortTypeProperty().addListener(sortTypeChangeListener);
clmGender.sortTypeProperty().addListener(sortTypeChangeListener);
reload();
//listen to sortorder change
tblMember.getSortOrder().addListener(new ListChangeListener<TableColumn<VOMember, ?>>() {
@Override
public void onChanged(Change<? extends TableColumn<VOMember, ?>> change) {
reload();
}
});
}
private void reload() {
/**
* Get sorted columns and sorting versus (ASC/DESC)
*/
List<String> lstSortedColumn = new ArrayList<String>();
List<String> lstSortedType = new ArrayList<String>();
for (TableColumn<VOMember, ?> tc : tblMember.getSortOrder()) {
PropertyValueFactory valFactory = (PropertyValueFactory) tc.getCellValueFactory();
valFactory.getProperty();
lstSortedColumn.add(valFactory.getProperty());
lstSortedType.add(tc.getSortType().name());
}
/**
* Retrieve data from database. Pass the sorting information
*/
List<VOMember> lstMember = controller.retrieve(lstSortedColumn, lstSortedType);
ObservableList<VOMember> data = FXCollections.observableList(lstMember);
tblMember.setItems(data);
}
class SortTypeChangeListener implements InvalidationListener {
@Override
public void invalidated(Observable o) {
/**
* If the column is not in sortOrder list, just ignore.
* It avoids intermittent duplicate reload() calling
*/
TableColumn col = (TableColumn) ((SimpleObjectProperty) o).getBean();
if (!tblMember.getSortOrder().contains(col)) {
return;
}
reload();
}
}
Run Code Online (Sandbox Code Playgroud)
我想听听您对此的看法/评论。
| 归档时间: |
|
| 查看次数: |
3480 次 |
| 最近记录: |