XmlAttributes.XmlArray Eigenschap

Definitie

Hiermee wordt een object opgehaald of ingesteld dat aangeeft hoe een XmlSerializer openbaar veld of een eigenschap lezen/schrijven wordt geserialiseerd die een matrix retourneert.

public:
 property System::Xml::Serialization::XmlArrayAttribute ^ XmlArray { System::Xml::Serialization::XmlArrayAttribute ^ get(); void set(System::Xml::Serialization::XmlArrayAttribute ^ value); };
public System.Xml.Serialization.XmlArrayAttribute XmlArray { get; set; }
member this.XmlArray : System.Xml.Serialization.XmlArrayAttribute with get, set
Public Property XmlArray As XmlArrayAttribute

Waarde van eigenschap

Een XmlArrayAttribute die aangeeft hoe een XmlSerializer openbaar veld of een eigenschap lezen/schrijven wordt geserialiseerd die een matrix retourneert.

Voorbeelden

In het volgende voorbeeld wordt een klasse geserialiseerd die een veld bevat dat Members een matrix met objecten retourneert. Deze XmlArrayAttribute wordt gebruikt om de serialisatie van het veld te overschrijven en de naam Staffvan het element te wijzigen in .

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

// This is the class that will be serialized.
public class Group
{
   // This field will be overridden.
   public Member [] Members;
}

public class Member
{
   public string MemberName;
}

public class Run
{
   public static void Main()
   {
      Run test = new Run();
      test.SerializeObject("OverrideArray.xml");
      test.DeserializeObject("OverrideArray.xml");
   }
   // Return an XmlSerializer used for overriding.
   public XmlSerializer CreateOverrider()
   {
      // Creating XmlAttributeOverrides and XmlAttributes objects.
      XmlAttributeOverrides xOver = new XmlAttributeOverrides();
      XmlAttributes xAttrs = new XmlAttributes();

      // Add an override for the XmlArray.
      XmlArrayAttribute xArray = new XmlArrayAttribute("Staff");
      xArray.Namespace = "http://www.cpandl.com";
      xAttrs.XmlArray = xArray;
      xOver.Add(typeof(Group), "Members", xAttrs);

      // Create the XmlSerializer and return it.
      return new XmlSerializer(typeof(Group), xOver);
   }

   public void SerializeObject(string filename)
   {
      // Create an instance of the XmlSerializer class.
      XmlSerializer mySerializer =  CreateOverrider();
      // Writing the file requires a TextWriter.
      TextWriter writer = new StreamWriter(filename);

      // Create an instance of the class that will be serialized.
      Group myGroup = new Group();

      // Set the object properties.
      Member m = new Member();
      m.MemberName = "Paul";
      myGroup.Members = new Member[1] {m};

      // Serialize the class, and close the TextWriter.
      mySerializer.Serialize(writer, myGroup);
      writer.Close();
   }

   public void DeserializeObject(string filename)
   {
      XmlSerializer mySerializer = CreateOverrider();
      FileStream fs = new FileStream(filename, FileMode.Open);
      Group myGroup = (Group)
      mySerializer.Deserialize(fs);
      foreach(Member m in myGroup.Members)
      {
         Console.WriteLine(m.MemberName);
      }
   }
}
Imports System.IO
Imports System.Xml
Imports System.Xml.Serialization


' This is the class that will be serialized.
Public Class Group
    ' This field will be overridden.
    Public Members() As Member
End Class

Public Class Member
    Public MemberName As String
End Class

Public Class Run
    
    Public Shared Sub Main()
        Dim test As New Run()
        test.SerializeObject("OverrideArray.xml")
        test.DeserializeObject("OverrideArray.xml")
    End Sub
    
    ' Return an XmlSerializer used for overriding. 
    Public Function CreateOverrider() As XmlSerializer
        ' Creating XmlAttributeOverrides and XmlAttributes objects.
        Dim xOver As New XmlAttributeOverrides()
        Dim xAttrs As New XmlAttributes()
        
        ' Add an override for the XmlArray.    
        Dim xArray As New XmlArrayAttribute("Staff")
        xArray.Namespace = "http://www.cpandl.com"
        xAttrs.XmlArray = xArray
        xOver.Add(GetType(Group), "Members", xAttrs)
        
        ' Create the XmlSerializer and return it.
        Return New XmlSerializer(GetType(Group), xOver)
    End Function
    
    Public Sub SerializeObject(ByVal filename As String)
        ' Create an instance of the XmlSerializer class.
        Dim mySerializer As XmlSerializer = CreateOverrider()
        ' Writing the file requires a TextWriter.
        Dim writer As New StreamWriter(filename)
        
        ' Create an instance of the class that will be serialized.
        Dim myGroup As New Group()
        
        ' Set the object properties.
        Dim m As New Member()
        m.MemberName = "Paul"
        myGroup.Members = New Member(0) {m}
        
        ' Serialize the class, and close the TextWriter.
        mySerializer.Serialize(writer, myGroup)
        writer.Close()
    End Sub    
    
    Public Sub DeserializeObject(ByVal filename As String)
        Dim mySerializer As XmlSerializer = CreateOverrider()
        Dim fs As New FileStream(filename, FileMode.Open)
        Dim myGroup As Group = CType(mySerializer.Deserialize(fs), Group)
        Dim m As Member
        For Each m In  myGroup.Members
            Console.WriteLine(m.MemberName)
        Next m
    End Sub
End Class

Opmerkingen

Er zijn twee manieren waarop een openbaar veld of een openbare lees-/schrijfeigenschap die een matrix retourneert, wordt geserialiseerd door: XmlSerializerde standaardserialisatie en de gecontroleerde serialisatie.

In de standaardserialisatie wordt geen kenmerk toegepast op het lid. Wanneer de matrix wordt geserialiseerd, wordt deze geserialiseerd als een geneste reeks XML-elementen met de naam van het XML-element van de geneste reeks die uit de lidnaam is genomen.

Als u de serialisatie nauwkeuriger wilt beheren, past u een XmlArrayAttribute waarde toe op het veld of de eigenschap. U kunt bijvoorbeeld de gegenereerde XML-elementnaam wijzigen van de standaardnaam in een andere naam door de ElementName eigenschap in te stellen op een nieuwe waarde.

Met XmlArray de eigenschap kunt u de standaardserialisatie overschrijven, evenals de serialisatie die wordt beheerd door een XmlArrayAttribute op het lid toe te passen. U kunt bijvoorbeeld de naam van het XML-element wijzigen die is gegenereerd op basis van de standaardwaarde (de lid-id) in een nieuwe waarde. Als u bovendien een XmlArrayAttribute lid toepast, wordt deze overschreven door een XmlArrayAttribute lid dat aan de XmlArray eigenschap is toegewezen.

Van toepassing op