Freigeben über


XmlAttributes.XmlText Eigenschaft

Definition

Dient zum Abrufen oder Festlegen eines Objekts, das die XmlSerializer Serialisierung eines öffentlichen Felds oder einer öffentlichen Lese-/Schreibeigenschaft als XML-Text anweist.

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

Eigenschaftswert

Eine XmlTextAttribute , die die Standard serialisierung einer öffentlichen Eigenschaft oder eines öffentlichen Felds außer Kraft setzt.

Beispiele

Im folgenden Beispiel wird die Klasse mit dem Namen Groupserialisiert, die ein Feld mit dem Namen Commententhält. Zum Überschreiben der Standardweise, auf der das XmlSerializer Feld serialisiert wird, erstellt das Beispiel ein XmlAttributeOverrides und ein XmlAttributes Objekt. Anschließend erstellt das Beispiel ein XmlTextAttribute Objekt, das der Eigenschaft zugewiesen XmlText wird, und fügt das XmlAttributes Objekt (mit dem Namen des Felds, das als XML-Text serialisiert werden soll) dem XmlAttributeOverrides Objekt hinzu. Zuletzt erstellt das Beispiel eine XmlSerializer Verwendung des XmlAttributeOverrides Objekts.

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

// This is the class that will be serialized.
public class Group
{
   public string GroupName;

   // This field will be serialized as XML text.
   public string Comment;
}

public class Run
{
   public static void Main()
   {
      Run test = new Run();
      test.SerializeObject("OverrideText.xml");
      test.DeserializeObject("OverrideText.xml");
   }

   // Return an XmlSerializer to be used for overriding.
   public XmlSerializer CreateOverrider()
   {
      // Create the XmlAttributeOverrides and XmlAttributes objects.
      XmlAttributeOverrides xOver = new XmlAttributeOverrides();
      XmlAttributes xAttrs = new XmlAttributes();

      /* Create an XmlTextAttribute and assign it to the XmlText
      property. This instructs the XmlSerializer to treat the
      Comment field as XML text. */
      XmlTextAttribute xText = new XmlTextAttribute();
      xAttrs.XmlText = xText;
      xOver.Add(typeof(Group), "Comment", 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.
      myGroup.GroupName = ".NET";
      myGroup.Comment = "Great Stuff!";
      // 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);
      Console.WriteLine(myGroup.GroupName);
      Console.WriteLine(myGroup.Comment);
   }
}
Imports System.IO
Imports System.Xml
Imports System.Xml.Serialization


' This is the class that will be serialized.
Public Class Group
    Public GroupName As String
    
    ' This field will be serialized as XML text. 
    Public Comment As String
End Class


Public Class Run
    
    Public Shared Sub Main()
        Dim test As New Run()
        test.SerializeObject("OverrideText.xml")
        test.DeserializeObject("OverrideText.xml")
    End Sub

        
    ' Return an XmlSerializer to be used for overriding. 
    Public Function CreateOverrider() As XmlSerializer
        ' Create the XmlAttributeOverrides and XmlAttributes objects.
        Dim xOver As New XmlAttributeOverrides()
        Dim xAttrs As New XmlAttributes()
        
        ' Create an XmlTextAttribute and assign it to the XmlText
        ' property. This instructs the XmlSerializer to treat the
        ' Comment field as XML text. 
        Dim xText As New XmlTextAttribute()
        xAttrs.XmlText = xText
        xOver.Add(GetType(Group), "Comment", 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.
        myGroup.GroupName = ".NET"
        myGroup.Comment = "Great Stuff!"
        ' 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)
        Console.WriteLine(myGroup.GroupName)
        Console.WriteLine(myGroup.Comment)
    End Sub
End Class

Hinweise

Standardmäßig wird ein öffentliches Feld oder eine öffentliche Lese-/Schreibeigenschaft als XML-Element von der XmlSerializer. Sie kann jedoch erzwingen, dass das Feld oder die Eigenschaft als XML-Text serialisiert wird, indem ein Feld oder eine XmlTextAttribute Eigenschaft angewendet wird.

Hinweis

Dies XmlTextAttribute kann nicht auf ein Feld oder eine Eigenschaft angewendet werden, das ein Array zurückgibt.

Wenn Sie die Standard serialisierung eines Felds oder einer Eigenschaft außer Kraft setzen möchten (das kein Array zurückgibt), erstellen Sie ein XmlTextAttribute Array, und weisen Sie es der XmlText Eigenschaft eines XmlAttributes Objekts zu. Fügen Sie das XmlAttributes Objekt zu einem XmlAttributeOverrides Objekt hinzu, und geben Sie den Typ des Objekts an, das das überschriebene Feld oder die Eigenschaft enthält, und den Namen des überschriebenen Felds oder der Eigenschaft.

Gilt für: