我可以使用从另一个控制器获得的参数到当前可初始化的参数吗?

问题描述:

我有两个不同的控制器,但通过获得一个特定的值,我想在第二个控制器的初始化时使用它。我可以使用从另一个控制器获得的参数到当前可初始化的参数吗?

这是其中第一控制器发送区域参数到另一CONTROLER

public void enterlevel(String x) throws IOException{ 

    FXMLLoader Loader=new FXMLLoader(); 

    Loader.setLocation(getClass().getResource(x)); 

    Loader.load(); 

    regionalController reg=Loader.getController(); 
    reg.getRegion(region); 


    //System.out.println(region); 

    Parent root = Loader.getRoot(); 

    Stage primaryStage = new Stage(); 
    Scene scene = new Scene(root); 

    primaryStage.setTitle("Ziga Ziga"); 
    primaryStage.setScene(scene); 
    primaryStage.setMaximized(true); 
    primaryStage.setResizable(false); 
    primaryStage.show(); 


    Stage stage = (Stage) loginButton.getScene().getWindow(); 
    stage.close(); 

} 

这部分,其中所述第二控制器得到它

public void getRegion(String region) { 
    System.out.println(region+" UO UO UO "); 
    regi=region; 
    } 

而这正是initializable其中我无法使用该值,因为它启动时

public void initialize(URL arg0, ResourceBundle arg1) {  
    System.out.println(regi); 
    try{ 
     Class.forName("com.mysql.jdbc.Driver"); 
     Connection con=DriverManager.getConnection("jdbc:mysql://localhost/bimbima","root",""); 
     Statement stmt=con.createStatement(); 
     ResultSet rs=stmt.executeQuery("SELECT * FROM `file` WHERE Region = '"+regi+"'"); 
     while(rs.next()) { 
     filename=rs.getString("filename"); 
     nameofSup=rs.getString("Name of Supervisor"); 
     System.out.println(filename); 
     } 
     con.close(); 
     }catch(Exception e){ System.out.println(e);} 
} 
+0

非常感谢你,那'getRegion(...)'只是停留因为我之前使用它来做其他事情。 – Eixhani

另外:当然你的getRegion(...)方法应该被称为setRegion(...),因为它改变了一个属性的值,并且不返回任何东西。

只需更改代码的第二个控制器,所以你只当你知道该地区从数据库中检索的值:

public void initialize(URL arg0, ResourceBundle arg1) {  
} 

public void setRegion(String region) { 
    regi=region; 
    try{ 
     Class.forName("com.mysql.jdbc.Driver"); 
     Connection con=DriverManager.getConnection("jdbc:mysql://localhost/bimbima","root",""); 
     Statement stmt=con.createStatement(); 
     ResultSet rs=stmt.executeQuery("SELECT * FROM `file` WHERE Region = '"+regi+"'"); 
     while(rs.next()) { 
     filename=rs.getString("filename"); 
     nameofSup=rs.getString("Name of Supervisor"); 
     System.out.println(filename); 
     } 
     con.close(); 
    } catch(Exception e) { 
     e.printStackTrace(); 
    } 
}