XmlAttributes.XmlAnyElements Eigenschap

Definitie

Hiermee haalt u de verzameling XmlAnyElementAttribute objecten op die moeten worden overschreven.

public:
 property System::Xml::Serialization::XmlAnyElementAttributes ^ XmlAnyElements { System::Xml::Serialization::XmlAnyElementAttributes ^ get(); };
public System.Xml.Serialization.XmlAnyElementAttributes XmlAnyElements { get; }
member this.XmlAnyElements : System.Xml.Serialization.XmlAnyElementAttributes
Public ReadOnly Property XmlAnyElements As XmlAnyElementAttributes

Waarde van eigenschap

Een XmlAnyElementAttributes object dat de verzameling XmlAnyElementAttribute objecten vertegenwoordigt.

Voorbeelden

In het volgende voorbeeld wordt een nieuw XmlAnyElementAttribute object gemaakt en toegevoegd aan de verzameling objecten die toegankelijk zijn via de XmlAnyElements eigenschap. Het XmlAttributes object wordt vervolgens toegevoegd aan een XmlAttributeOverrides object dat wordt gebruikt om een XmlSerializer object te maken. Het XmlSerializer object wordt gebruikt om een object te serialiseren of deserialiseren. Als u het effect van het gebruik van de eigenschap wilt zien, maakt u een XML-document met de XmlAnyElementAttributes naam 'UnknownElements.xml' door de SerializeObject methode uit te voeren in de Main methode. Bewerk het resulterende document om andere (onbekende) elementen op te nemen. Markeer de SerializeObject aanroep in de Main methode als commentaar en verwijder commentaar bij de aanroep naar de DeserializeObject methode, waarmee de naam en waarde van een onbekend XML-element worden afgedrukt.

using System;
using System.IO;
using System.Xml.Serialization;
using System.Xml;

public class Group{
   public string GroupName;
   [XmlAnyElement]
   public object[]Things;
}

public class Test{
   static void Main(){
      Test t = new Test();
      // 1 Run this and create the XML document.
      // 2 Add new elements to the XML document.
      // 3 Comment out the new line, and uncomment
      // the DeserializeObject line to deserialize the
      // XML document and see unknown elements.
      t.SerializeObject("UnknownElements.xml");
     
      // t.DeserializeObject("UnknownElements.xml");
   }

   private void SerializeObject(string filename){
      XmlSerializer ser = new XmlSerializer(typeof (Group));
      TextWriter writer = new StreamWriter(filename);
      Group g = new Group();
      g.GroupName = "MyGroup";
      ser.Serialize(writer, g);
      writer.Close();
   }

   private void DeserializeObject(string filename){

      XmlSerializer ser = CreateOverrideSerializer();
      // A FileStream is needed to read the XML document.
      FileStream fs = new FileStream(filename, FileMode.Open);
     Group g = (Group)
        ser.Deserialize(fs);
     fs.Close();
     Console.WriteLine(g.GroupName);
     Console.WriteLine(g.Things.Length);
     foreach(XmlElement xelement in g.Things){
     Console.WriteLine(xelement.Name + ": " + xelement.InnerXml);
     }
   }

   private XmlSerializer CreateOverrideSerializer(){
      XmlAnyElementAttribute myAnyElement = 
      new XmlAnyElementAttribute();
      XmlAttributeOverrides xOverride = 
      new XmlAttributeOverrides();
      XmlAttributes xAtts = new XmlAttributes();
      xAtts.XmlAnyElements.Add(myAnyElement);
      xOverride.Add(typeof(Group), "Things", xAtts);
      return new XmlSerializer(typeof(Group) , xOverride);
   }
}
Imports System.IO
Imports System.Xml.Serialization
Imports System.Xml

Public Class Group
   Public GroupName As String 
   <XmlAnyElement> _
   Public Things () As object
End Class

Public Class Test
   Shared Sub Main()
      Dim t As Test = New Test()
      ' 1 Run this and create the XML document.
      ' 2 Add New elements to the XML document.
      ' 3 Comment out the New line, and uncomment
      ' the DeserializeObject line to deserialize the
      ' XML document and see unknown elements.
     t.SerializeObject("UnknownElements.xml")
     
      't.DeserializeObject("UnknownElements.xml")
   End Sub

   Private Sub SerializeObject(filename As String)
      Dim ser As XmlSerializer = New XmlSerializer(GetType (Group))
      Dim writer As TextWriter = New StreamWriter(filename)
      
      Dim g As Group = New Group()
      g.GroupName = "MyGroup"
      ser.Serialize(writer, g)
      writer.Close()
   End Sub

   
   Private Sub DeserializeObject(filename As String)

      Dim ser As XmlSerializer = CreateOverrideSerializer()
      ' A FileStream is needed to read the XML document.
      Dim fs As FileStream = New FileStream(filename, FileMode.Open)
     Dim g As Group = CType( _
        ser.Deserialize(fs), Group)
     fs.Close()
     Console.WriteLine(g.GroupName)
     Console.WriteLine(g.Things.Length)
     Dim xelement As XmlELement
     for each xelement in g.Things
        Console.WriteLine(xelement.Name &": " & xelement.InnerXml)
     next
   End Sub
   

   Private Function CreateOverrideSerializer() As XmlSerializer 
      Dim myAnyElement As XmlAnyElementAttribute = _
      New XmlAnyElementAttribute()
      Dim xOverride As XmlAttributeOverrides = _
      New XmlAttributeOverrides()
      Dim xAtts As XmlAttributes = New XmlAttributes()
      xAtts.XmlAnyElements.Add(myAnyElement)
      xOverride.Add(GetType(Group), "Things", xAtts)
      return New XmlSerializer(GetType(Group) , xOverride)
   End Function
End Class

Opmerkingen

De XmlAnyElementAttribute kan worden toegepast op een lid dat een matrix met XmlElement objecten op deserialisatie retourneert. Hierdoor kunnen XmlSerializer alle elementen die geen bijbehorend lid in het object hebben, deserialiseren, waardoor deze elementen "onbekend" zijn voor de XmlSerializer. Dit is handig wanneer de XML-stroom is gewijzigd door een XML-webservice of wanneer bekend is dat willekeurige gegevens altijd worden opgenomen in de XML-stroom.

Met XmlAnyElements de eigenschap kunt u de serialisatie van een lid overschrijven om te functioneren als lid waarop de XmlAnyElementAttribute eigenschap is toegepast.

Van toepassing op

Zie ook