从DynamicForm获取所有字段

时间:2012-10-18 10:11:41

标签: xsd smartgwt

我使用从xsd schema生成的DataSource。我需要从DataSource获取所有字段,也是嵌套的字段。我的问题与this topic from Smartclient forum forum中的问题相同,当我使用DataSource.getFields()时,它只返回第一级字段。

有谁知道如何获得嵌套字段?

2 个答案:

答案 0 :(得分:1)

我不确定这是否能解决您的问题。 CompanySlaves不是xsd中任何位置的引用。类型已定义但未使用。

我认为您需要<xsd:element name="SomeElementName" type="tns:CompanySlaves"></xsd:element> in your xsd definition

<?xml version="1.0" encoding="UTF-8"?>
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"
            targetNamespace="http://xml.netbeans.org/schema/newXmlSchema"
    xmlns:tns="http://xml.netbeans.org/schema/newXmlSchema"
    elementFormDefault="qualified">
    <xsd:element name="SubrogationClaim" type="tns:SubrogationClame"></xsd:element>
    <xsd:complexType name="SubrogationClame">
        <xsd:sequence>
            <xsd:element name="CompanyName" type="xsd:string"></xsd:element>
            <xsd:element name="CompanyPlace" type="xsd:string"></xsd:element>
            <xsd:element name="CompanyEmploee" type="tns:SubrogationClame"></xsd:element>
        </xsd:sequence>
    </xsd:complexType>
    <xsd:complexType name="CompanySlaves">
        <xsd:sequence>
            <xsd:element name="EmploeeName" type="xsd:string"></xsd:element>
            <xsd:element name="EmploeeSalary" type="xsd:string"></xsd:element>
        </xsd:sequence>
    </xsd:ComplexType>
</xsd:schema>

答案 1 :(得分:0)

我找到了解决方案要获取嵌套字段,可以使用DataSource.getDataSource(ID)。例如,如果dataSource是主DataSource,则可以这样做:

    private List<DataSourceField> getAllFields(DataSource dataSource)
    {
        List <DataSourceField> fieldList = new ArrayList<DataSourceField>();
        DataSourceField [] fields = dataSource.getFields();
        fieldList.addAll(Arrays.asList(fields));
        for (DataSourceField field : fields);
        {
            String fieldName = field.getName();
            DataSource ds = DataSource.getDataSource(fieldName);
            if (ds != null)
            {
                fieldList.remove(field);
                DataSourceField[] nFields = ds.getFields();
                fieldList.addAll(Arrays.asList(nFields));
                getAllFields(ds);
            }
        }
        return fieldList;
    }