Usando fx: id como CSS id no FXML
Parece que em FXML, se você não especificar um ID (CSS), o valor fx: id será usado por padrão. Meu entendimento anterior era que os dois eram completamente disjuntos, ID para CSS e apenas CSS. fx: id para ligações @FXML no controlador.
Isso pode ser demonstrado com um pequeno teste - três botões, primeiro com ID, segundo com FX: ID, terceiro com ambos os tipos de ID.
<VBox maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="400.0" prefWidth="600.0" xmlns="http://javafx.com/javafx/8" xmlns:fx="http://javafx.com/fxml/1">
<children>
<Button id="cssid0" mnemonicParsing="false" text="Button" />
<Button fx:id="fxid1" mnemonicParsing="false" text="Button" />
<Button id="cssid2" fx:id="fxid2" mnemonicParsing="false" text="Button" />
</children>
</VBox>
O uso de Node.lookup (cssSelector) permite a seleção por fx: id
@Override
public void start(Stage stage) throws Exception {
FXMLLoader loader = new FXMLLoader(getClass().getResource("/foo.fxml"));
Parent p = loader.load();
System.out.println(p.lookup("#cssid0")); // => Button[id=cssid0, styleClass=button]'Button'
System.out.println(p.lookup("#fxid1")); // => Button[id=fxid1, styleClass=button]'Button'
System.out.println(p.lookup("#fxid2")); // => null (if there is a CSS ID it takes precedent)
System.out.println(p.lookup("#cssid2")); // Button[id=cssid2, styleClass=button]'Button'
stage.setScene(new Scene(p, 200, 200));
stage.getScene().getStylesheets().add("/foo.css");
stage.show();
}
CSS também permite a seleção pelo fx: ID
#cssid0 {
-fx-color: red;
}
#fxid1 {
-fx-color: green;
}
#cssid2 {
-fx-color: blue;
}
Isso não parece ser coberto pela pergunta existenteQual é a diferença entre fx: id e id: em JavaFX?, Javadoc paraNode.getId () ou em qualquer outro lugar que eu pudesse encontrar.
Esse recurso é realmente útil, pois precisamos especificar apenas um único fx: id que pode ser usado para controladores, CSS e testes de unidade usando test-FX.
Posso usar essa abordagem ou estou construindo suposições sobre comportamento não documentado que pode mudar em uma versão posterior? Ou está documentado em algum lugar que estou perdendo?