我有这个javaFX接口,它包含一个简单的BorderPane根布局。当在rootLayout菜单上按下按钮时,我想要的两个AnchorPane交替设置在rootLayout的中心。 它工作正常,但有一件事我很难理解。 当按下按钮时,我正在使用rootlayout控制器调用方法。虽然它应该只在执行两次后执行!
为了给出基本想法,这里涉及的代码如下:
处理位于根布局控制器中的按钮操作的方法:
@FXML
private void handleStockWizardButton(){
mainApp.updateProduct(0,10);
mainApp.showStockWizard();
}
它正在填充一个Observable列表,该列表稍后会传递给第二个页面控制器,以便在表格视图中显示它们。显示此视图并设置每个事物的方法如下:
public void showStockWizard(){
try {
FXMLLoader loader = new FXMLLoader();
loader.setLocation(MainApp.class.getResource("view/StockWizard.fxml"));
AnchorPane StockWizard = (AnchorPane) loader.load();
rootLayout.setCenter(StockWizard);
StockWizardController controller = loader.getController();
controller.setMainApp(this);
controller.setProduct(product);
} catch (IOException e){
e.printStackTrace();
}
}
这里困扰我的是在loader.load()上调用handleStockWizardButton()方法,虽然与这里的构造函数没有关系,但是调用了!
我缺少负载方法的某些方面吗?
编辑:
以下是一些涉及的代码:
要显示的视图的控制器,设置一些值工厂并设置一些监听器,不应该发送回根控制器:
@FXML
private void initialize(){
productNameColumn.setCellValueFactory(CellData -> CellData.getValue().nameProperty());
productReferenceColumn.setCellValueFactory(CellData -> CellData.getValue().referenceProperty());
productUnitSellingPriceColumn.setCellValueFactory(CellData -> CellData.getValue().unitSellingPriceProperty());
displayChoices.add("10");
displayChoices.add("25");
displayChoices.add("50");
displayChoiceBox.setItems(displayChoices);
displayChoiceBox.setValue("10");
displayChoiceBox.getSelectionModel().selectedItemProperty().addListener((observable, oldValue, newValue) -> setDisplayValue());
currentPage.setText("1");
}
updateproducts方法的详细信息在这里没有用,因为它只是访问Web服务并处理收到的行。它很干净。
这是rootlayout borderPane的FXML文件,这里要注意的是在操作上调用handleButton的菜单项:
<?xml version="1.0" encoding="UTF-8"?>
<?import javafx.scene.control.*?>
<?import java.lang.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.layout.BorderPane?>
<BorderPane minHeight="540.0" prefHeight="720.0" prefWidth="1280.0" xmlns="http://javafx.com/javafx/8.0.40" xmlns:fx="http://javafx.com/fxml/1" fx:controller="prestashopwebservice.view.RootController">
<top>
<MenuBar BorderPane.alignment="CENTER">
<menus>
<Menu mnemonicParsing="false" onAction="#handleConfigure" text="Configuration">
<items>
<MenuItem mnemonicParsing="false" onAction="#handleConfigure" text="open configuration" />
</items></Menu>
<Menu mnemonicParsing="false" onAction="#handleStockWizard" text="StockWizard">
<items>
<MenuItem mnemonicParsing="false" onAction="#handleStockWizardButton" text="open StockWizard" />
</items></Menu>
</menus>
</MenuBar>
</top>
</BorderPane>
答案 0 :(得分:1)
除非消费,否则onAction
事件将通过菜单结构向上传播。因此,如果您点击open configuration
MenuItem
而handleConfigure
不会消耗该事件,则会再次针对Configuration
Menu
触发该事件。
通过在处理程序方法中调用Event.consume
来防止这种情况,例如
@FXML
private void handleConfigure(ActionEvent evt) {
...
evt.consume();
}
或者只是从onAction
中删除Menu
属性(如有必要,可以将其替换为onShown
或onHidden
。