对象序列化和派生类;控制xml输出

时间:2011-04-29 13:16:06

标签: c# xml serialization

我有2个派生类将被序列化为xml 虽然代码工作正常(XmlSerializer,没什么奇怪的),但DataScenario的序列化导致其MyData属性项从基类名生成Xmlelement名称:

<DataScenario>
  <MyData>
    <ScenarioData/>
    <ScenarioData/>
    <ScenarioData/>
  </MyData>
<DataScenario>

相反,我试图让这些项目从派生类中生成XmlElement名称

<DataScenario>
  <MyData>
    <type1/>
    <type1/>
    <type2/>
  </MyData>
<DataScenario>

这甚至可能吗?请记住,我也需要反序列化;我不确定反序列化过程是否会理解需要创建派生对象。

我使用的示例代码如下。

[Serializable]
[XmlInclude(typeof(Type1))]
[XmlInclude(typeof(Type2))]
public class Scenario
    {
        [XmlElement("location")]
        public string Location { get; set; }
        [XmlElement("value")]
        public string Value { get; set; }

        public Scenario()
        {
        }
    }

[Serializable]
[XmlType("type1")]
public class Type1 : Scenario
    {
        public FillPointData() : base() { }            
    }


[Serializable]
[XmlType("type2")]
public class Type2 : Scenario
    {
        public TestData() : base() { }            
    }


//Hosting class of all scenarios
public DataScenario()
    {
        public List<Scenario> MyData{ get; set; }
    }

1 个答案:

答案 0 :(得分:4)

您可以使用XmlArrayItem属性定义Collection中的哪种元素。 如果Type已知(定义为您使用XmlInclude属性),它将创建标签“Type1”,“Type2”。如果类型未知,它仍将创建一个名为ScenarioData的标签,其属性为xsi:type =“Type1”,用于在反序列化时映射类型。

[XmlArrayItem(typeof(Type1))] 
[XmlArrayItem(typeof(Type2))] 
Public List<Scenario> Children
{
// getter & setter
}