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

我有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)

3 years ago

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

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