我制作了一张简单的表格,用户可以在其中搜索书籍并购买它。在一个场景中有搜索标签,并且当点击搜索按钮时,新的场景以表格中的搜索结果打开。问题是,当我输入例如要搜索的书名时,它会显示在表格中,但是当我返回时,输入新书名进行搜索时,表格中会有与之前搜索相同的单元格。我希望旧的搜索记录在我输入新的搜索参数时不显示。我不使用JavaFX属性,因为我从服务器获取书籍,并且JavaFX属性不可序列化。这就像表没有令人耳目一新。我试图从本网站的类似问题实现代码,但没有结果。 我的表的代码(最后一列是复选框)。表中的JavaFX旧单元格以新单元格显示
TableView<Knjiga> table = new TableView<Knjiga>();
ObservableList<Knjiga> data =
FXCollections.observableArrayList(list);
table.setColumnResizePolicy(TableView.CONSTRAINED_RESIZE_POLICY);
TableColumn<Knjiga, String> nameCol = new TableColumn<Knjiga, String>("Naziv");
TableColumn<Knjiga, String> authorCol = new TableColumn<Knjiga, String>("Autor");
TableColumn<Knjiga, String> costCol = new TableColumn<Knjiga, String>("Cijena");
Callback<TableColumn<Knjiga, Boolean>, TableCell<Knjiga, Boolean>> cellFactory;
TableColumn checkCol= new TableColumn<Knjiga, Boolean>();
table.setItems(data);
nameCol.setCellValueFactory(new PropertyValueFactory<Knjiga, String>("bookName"));
authorCol.setCellValueFactory(new PropertyValueFactory<Knjiga, String>("authorName"));
costCol.setCellValueFactory(new PropertyValueFactory<Knjiga, String>("cost"));
checkCol.setCellValueFactory(new PropertyValueFactory<Knjiga, Boolean>("checked"));
cellFactory = new Callback<TableColumn<Knjiga, Boolean>, TableCell<Knjiga, Boolean>>() {
@Override
public TableCell call(final TableColumn param) {
final CheckBox checkBox = new CheckBox();
final TableCell cell = new TableCell() {
@Override
public void updateItem(Object item, boolean empty) {
super.updateItem(item, empty);
if (item == null) {
checkBox.setDisable(true);
checkBox.setSelected(false);
} else {
checkBox.setDisable(false);
checkBox.setSelected(item.equals(true) ? true : false);
checkBox.selectedProperty().addListener(new ChangeListener<Boolean>() {
@Override
public void changed(ObservableValue<? extends Boolean> observable, Boolean oldValue, Boolean newValue) {
for(int i = 0; i < fromServer.size(); i++)
fromServer.get(i).setQuantity(fromServer.get(i).getQuantity() - 1);
}
});
commitEdit(checkBox.isSelected() ? true : false);
}
}
};
cell.setGraphic(checkBox);
refresh(table, data);
return cell;
}
};
checkCol.setCellValueFactory(new PropertyValueFactory("checked"));
checkCol.setCellFactory(cellFactory);
另外:仅仅因为JavaFX属性不是'Serializable',它并不意味着你的模型类不能使用它们。通过实现'readObject'和'writeObject'方法来使用自定义序列化。参见例如[here](http://www.oracle.com/technetwork/articles/java/javaserial-1536170.html)或[here](http://stackoverflow.com/questions/35039557/javafx-and-serializability)。 (还有......不是每个人都只是用最近的JSON与服务器通信吗?) –
是的,他们这样做。问题是我不能使用JSON,因为它不适用于我的应用程序。 (大学项目)。 – MGKP
够公平的。无论如何,请考虑使用JavaFX属性,它使控件能够更好地发挥作用。 –