我对此方法有疑问,因为我在vbox中使用此方法从子类中获取价值。
我从数据库获得的值,如果我使用addAll(),则数据库中的数据始终会增加,但是如果我使用setAll(),数据将不再增加,而只会在数据库中显示最后一列。
代码类似于vbox.getChildren().addAll(node);
或vbox.getChildren().setAll(node);
。
如何解决此问题?
@FXML
private void CB(ActionEvent event) {
String depart = comboBox.getValue();
String sql = "SELECT b.kota, bb.kota, single.harga FROM single_trip as single \n" +
"INNER JOIN departure as depart ON depart.kode_departure = single.kode_departure \n" +
"INNER JOIN bandara as b on b.kode_bandara = depart.kode_bandara \n" +
"INNER JOIN arrived as arrive on arrive.kode_arrived = single.kode_arrived \n" +
"INNER JOIN bandara as bb on bb.kode_bandara = arrive.kode_bandara \n" +
"WHERE b.nama_bandara = '"+depart+"'";
try {
con.st = con.conn.createStatement();
con.rs = con.st.executeQuery(sql);
Node[] nodes = new Node[1];
while(con.rs.next()){
for(Node node : nodes){
FXMLLoader hb = new FXMLLoader(getClass().getResource("ComboBoxloop.fxml"));
node = hb.load();
String namaDepart = con.rs.getString("b.kota");
String namaArrive = con.rs.getString("bb.kota");
int harga = con.rs.getInt("single.harga");
ComboBoxloopController controller = hb.getController();
controller.getValueFromCB(namaDepart, namaArrive, harga);
controller.setDepart(namaDepart);
controller.setArrive(namaArrive);
controller.setHarga(harga);
pnlComboBoxloop.getChildren().addAll(node);
// or pnlComboBoxloop.getChildren().setAll(node);
}
}
} catch (SQLException | IOException ex) {
Logger.getLogger(FXMLDocumentController.class.getName()).log(Level.SEVERE, null, ex);
}
}
对不起,我的英语不好
答案 0 :(得分:0)
addAll()方法接受您的输入并将其添加到现有值。对于3个元素的基本列表,然后将输入添加到3个元素(列表大小= 3 + input.size)。
boolean addAll(E ... elements)
一种方便的var-arg添加元素的方法。
setAll()方法将擦除现有值并将其替换为给定的输入(列表大小= input.size)
boolean setAll(E ... elements)
清除ObservableList并添加所有以var-args形式传递的元素。
参考:https://docs.oracle.com/javase/8/javafx/api/javafx/collections/ObservableList.html