0

我的 JavaFX 应用程序应如下所示:

在此处输入图像描述

现在,我想确保在我从表格视图中选择另一个人时,详细信息视图会立即适应。

到目前为止我的课程:

public class Person {
    private final StringProperty name = new SimpleStringProperty();
    private final StringProperty title = new SimpleStringProperty();
    private final IntegerProperty age = new SimpleIntegerProperty();

    public Person(String name, String title, int age) {
        setName(name);
        setTitle(title);
        setAge(age);
    }
    // Getters and Setters
}

public class PresentationModel {

    private final ObservableList<Person> persons = FXCollections.observableArrayList();
    private final ObjectProperty<Person> selectedPerson = new SimpleObjectProperty<>();

    public PresentationModel() {
        // add some users to persons list
    }

  // Getters/Setters

}

在带有表的 UI 类中,我设置了这样的侦听器:

personsTable.getSelectionModel().selectedItemProperty().addListener((observable, oldPerson, newPerson) -> {
    model.setSelectedPerson(newPerson);
});

在带有详细信息视图的 UI 类中,我设置了一个绑定:

nameLabel.textProperty().bind(model.getSelectedPerson().nameProperty());

PresentationModel model属性在应用程序启动时创建一次,然后通过构造函数传递给所有 UI 类。

但是这个绑定没有按预期工作。我可以更改什么以使绑定正常工作并且属性更改?

4

1 回答 1

1

绑定不起作用,因为getSelectedPerson仅返回当前选定的人员,并且如果选定的人员发生更改,则不会重新计算。

仅使用标准 API,您就可以做到

nameLabel.textProperty().bind(Bindings.selectString(
    model.selectedPersonProperty(), "name"));

这个 API 在很多方面都有些不尽人意。一方面,没有编译时检查selectedPersonProperty()有 a nameProperty(),并且它是正确的类型。其次,它使用反射,在您经常调用它的情况下效果不佳(此处不适用)。最后,如果所选人员为空,这会将大量多余的警告转储到标准输出(尽管 API 文档表明这是受支持的用例!!!)。

ReactFX 框架提供了一个替代方案:

nameLabel.textProperty().bind(Val.selectVar(
    model.selectedPersonProperty(), Person::nameProperty));
于 2017-04-26T13:16:09.863 回答