JavaFX - 使用XML中的数据填充FXML TableView

时间:2016-09-28 15:45:46

标签: java xml javafx

我正在尝试使用XML中的数据在JavaFX中填充TableView。基本上,我正在解析XML和XML中的数据。尝试使用XML中的数据设置tableview。 但是,我遇到了我提出的代码中的问题。以下是我的XML文件的格式。

XML文件

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<Root>
<xpression>
<Environment>
    <ProjectName>ABC</ProjectName>
    <EnvironmentName>ABC Server</EnvironmentName>   
    <ServerURL>abcc.com:8080</ServerURL>
    <SetDefault>Yes</SetDefault>
</Environment>
<Environment>
    <ProjectName>XYZ</ProjectName>
    <EnvironmentName>XYZ Server</EnvironmentName>
    <ServerURL>xyz.com:8080</ServerURL>
    <SetDefault>No</SetDefault>
</Environment>
</xpression>
</Root>

以下是我的XML解析代码:

XML分析器

public void parseXml() throws ParserConfigurationException, SAXException, IOException{
        DocumentBuilderFactory db = DocumentBuilderFactory.newInstance();
        DocumentBuilder dBuilder = db.newDocumentBuilder();
        Document doc = dBuilder.parse(xmlFile);
        doc.getDocumentElement().normalize();
        ObservableList<DataSource> data = FXCollections.observableArrayList();
        NodeList nList = doc.getElementsByTagName("Environment");
        DataSource ds = new DataSource();

        int j = 1;
        for(int i = 0; i < nList.getLength(); i++){
            Node nNode = nList.item(i);
             System.out.println("\nCurrent Element :" 
                       + nNode.getNodeName());

             if (nNode.getNodeType() == Node.ELEMENT_NODE){
                 Element element = (Element) nNode;
                 ds.setProjectName(element
                          .getElementsByTagName("ProjectName")
                          .item(0)
                          .getTextContent());
                 System.out.println(element
                          .getElementsByTagName("ProjectName")
                          .item(0)
                          .getTextContent());

                 ds.setEnvironment(element
                          .getElementsByTagName("EnvironmentName")
                          .item(0)
                          .getTextContent());
                 System.out.println(element
                          .getElementsByTagName("EnvironmentName")
                          .item(0)
                          .getTextContent());

                 ds.setServerURL(element
                          .getElementsByTagName("ServerURL")
                          .item(0)
                          .getTextContent());
                 System.out.println(element
                          .getElementsByTagName("ServerURL")
                          .item(0)
                          .getTextContent());

                 ds.setDefaultValue(element
                          .getElementsByTagName("SetDefault")
                          .item(0)
                          .getTextContent());
                 System.out.println(element
                          .getElementsByTagName("SetDefault")
                          .item(0)
                          .getTextContent());

                 ds.setSerialNo(j);
                 ++j;
             }
             //list.add(ds);
             data.add(ds);
        }
        //data = FXCollections.observableArrayList(list);
        tblDetails.setItems(data);
    }

数据源(POJO)文件:

public class DataSource {
    public SimpleIntegerProperty serialNo = new SimpleIntegerProperty();
    public SimpleStringProperty projectName = new SimpleStringProperty("");
    public SimpleStringProperty environment = new SimpleStringProperty("");
    public SimpleStringProperty serverURL = new SimpleStringProperty("");
    public SimpleStringProperty defaultValue = new SimpleStringProperty("");

    public DataSource(){
        this(1,"","","","");
    }

    public DataSource(int serial, String projectName,String envName, String serverURL, String defaultValue){
        setSerialNo(serial);
        setEnvironment(envName);
        setProjectName(projectName);
        setServerURL(serverURL);
        setDefaultValue(defaultValue);
    }

    public Integer getSerialNo(){
        return serialNo.get();
    }

    public void setSerialNo(Integer serialNum){
        serialNo.set(serialNum);
    }

    public String getProjectName(){
        return projectName.get();
    }

    public void setProjectName(String prjName){
        projectName.set(prjName);
    }

    public String getEnvironment(){
        return environment.get();
    }

    public void setEnvironment(String envName){
        environment.set(envName);
    }

    public String getServerURL(){
        return serverURL.get();
    }

    public void setServerURL(String serverUrl){
        serverURL.set(serverUrl);
    }

    public String getDefaultValue(){
        return defaultValue.get();
    }

    public void setDefaultValue(String defaultInd){
        defaultValue.set(defaultInd);
    }
}

基本上发生的事情是,当我尝试在我的parseXML()中设置表数据时,它正在从TableView中的XML文件设置第二个Environment实例的值,跳过第一个实例。见下面的截图: enter image description here

我尝试了各种各样的东西,但没有任何效果。有人可以指出错误或者可能为使用XML值填充JavaFX TableView提供解决方案吗?

1 个答案:

答案 0 :(得分:1)

您需要在DataSource循环中创建for的新实例,否则您将始终将相同的参考添加到ObservableList

执行此操作:

for(int i = 0; i < nList.getLength(); i++){
    DataSource ds = new DataSource();

代替:

DataSource ds = new DataSource();
...
for(int i = 0; i < nList.getLength(); i++){