JavaFX 属性

由 haiguiking 创建,小路依依 最后一次修改 2017-01-09

JavaFX教程 - JavaFX属性


JavaFX属性存储控件的内部状态,并允许我们监听来自JavaFX UI控件的状态更改。

JavaFX属性可以彼此绑定。绑定行为允许属性根据来自另一个属性的更改值来同步其值。

JavaFX属性的类型

有两种类型的JavaFX属性:

  • 读/写
  • 只读

JavaFX的属性包含实际值,并提供更改支持,无效支持和绑定功能。

所有JavaFX属性类都位于 javafx.beans.property.* 包命名空间中。

下面的列表是常用的属性类。

  • javafx.beans.property.SimpleBooleanProperty
  • javafx.beans.property.ReadOnlyBooleanWrapper
  • javafx.beans.property.SimpleintegerProperty
  • javafx.beans.property.ReadOnlyintegerWrapper
  • javafx.beans.property.SimpleDoubleProperty
  • javafx.beans.property.ReadOnlyDoubleWrapper
  • javafx.beans.property.SimpleStringProperty
  • javafx.beans.property.ReadOnlyStringWrapper

Simple 的属性是读/写属性类。具有 ReadOnly 的属性是只读属性。


读/写属性

读/写属性是可以读取和修改的属性值。

例如, SimpleStringProperty 类创建一个字符串属性,该属性对包装的字符串值是可读写的。

以下代码演示了一个 SimpleStringProperty 类的实例,并通过set()方法修改该属性。

import javafx.beans.property.SimpleStringProperty;
import javafx.beans.property.StringProperty;

public class Main{
  public static void main(String[] args) {
    StringProperty password  = new SimpleStringProperty("w3cschool.cn");
    password.set("example.com");
    System.out.println("Modified StringProperty "  + password.get() );
  }
}

上面的代码生成以下结果。

上面的代码声明了类型 StringProperty 的变量 password ,并分配给SimpleStringProperty 类的一个实例。

实际的值是字符串“w3cschool.cn",它被传递到 SimpleStringProperty 类的构造函数中。

要读取值,请调用 get()方法或 getValue()方法,该方法返回实际的包装值。

要修改该值,请调用 set()方法或 setValue()并传入一个字符串。


只读属性

要创建只读属性,请使用以 ReadOnly 作为前缀的包装类。

创建只读属性需要两个步骤。

  1. 实例化只读包装类
  2. 调用方法getReadOnlyProperty()返回一个真正的只读属性对象
ReadOnlyStringWrapper userName = new ReadOnlyStringWrapper("www.w3cschool.cn"); 
ReadOnlyStringProperty readOnlyUserName  = userName.getReadOnlyProperty();

JavaFX JavaBean

以下代码显示了如何创建JavaFX JavaBean。当构建基于Swing的应用程序时,我们使用getter和setter创建JavaBean。

然后我们必须通过Swing模型类在UI逻辑中获取和设置数据。通过使用JavaFX属性创建JavaFX JavaBean,JavaFX将执行数据绑定,并完成域模型类和UI控件之间的数据交换作业。

import javafx.beans.property.ReadOnlyStringProperty;
import javafx.beans.property.ReadOnlyStringWrapper;
import javafx.beans.property.SimpleStringProperty;
import javafx.beans.property.StringProperty;

class User {
  private final static String USERNAME_PROP_NAME = "userName";
  private final ReadOnlyStringWrapper userName;
  private final static String PASSWORD_PROP_NAME = "password";
  private StringProperty password;

  public User() {
    userName = new ReadOnlyStringWrapper(this, USERNAME_PROP_NAME,"fake user");
    password = new SimpleStringProperty(this, PASSWORD_PROP_NAME, "");
  }
  public final String getUserName() {
    return userName.get();
  }

  public ReadOnlyStringProperty userNameProperty() {
    return userName.getReadOnlyProperty();
  }

  public final String getPassword() {
    return password.get();
  }

  public final void setPassword(String password) {
    this.password.set(password);
  }

  public StringProperty passwordProperty() {
    return password;
  }
}

属性更改事件

属性可以通知值更改事件处理程序,以在属性更改时进行响应。

JavaFX属性对象包含一个addListener()方法,它接受两种类型的功能接口:ChangeListener和invalidationListener。

所有JavaFX属性都是ObservableValue和Observable接口的后代,它们分别为ChangeListener和invalidationListener提供了addListener()方法。

以下代码显示如何创建要注册到属性的ChangeListener。随着属性的值改变,将调用change()方法。

import javafx.beans.property.SimpleIntegerProperty;
import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;

public class Main {
  public static void main(String[] args) {
    SimpleIntegerProperty xProperty = new SimpleIntegerProperty(0);

    // Adding a change listener with anonymous inner class
    xProperty.addListener(new ChangeListener<Number>() {
      @Override
      public void changed(ObservableValue<? extends Number> ov, Number oldVal,
          Number newVal) {
        System.out.println("old value:"+oldVal);
        System.out.println("new value:"+newVal);
      }
    });

    // Adding a change listener with lambda expression
    xProperty.addListener((ObservableValue<? extends Number> ov, Number oldVal,
        Number newVal) -> {
          System.out.println("old value:"+oldVal);
          System.out.println("new value:"+newVal);
      });
  }
}

以下代码显示如何创建一个invalidationListener以向属性注册。随着属性的值更改,将调用invalidated()方法。

import javafx.beans.InvalidationListener;
import javafx.beans.Observable;
import javafx.beans.property.SimpleIntegerProperty;

public class Main {
  public static void main(String[] args) {
    SimpleIntegerProperty xProperty = new SimpleIntegerProperty(0);

    // Adding a invalidation listener (anonymous inner class)
    xProperty.addListener(new InvalidationListener() {
      @Override
      public void invalidated(Observable o) {
        System.out.println(o.toString());
      }
    });

    // Adding a invalidation listener (lambda expression)
    xProperty.addListener((Observable o) -> {
      System.out.println(o.toString());
    });

  }
}

ChangeListener和invalidationListener之间的区别。

  • 使用ChangeListener,我们将获得Observable(ObservableValue),旧值和新值。
  • 使用invalidationListener只获取Observable对象(属性)
以上内容是否对您有帮助:
二维码
建议反馈
二维码