XmlAttributes.XmlText-Eigenschaft
Ruft ein Objekt ab, mit dem XmlSerializer angewiesen wird, ein öffentliches Feld oder eine öffentliche Lese-/Schreibeigenschaft als XML-Text zu serialisieren, oder legt dieses fest.
Namespace: System.Xml.Serialization
Assembly: System.Xml (in system.xml.dll)
Syntax
'Declaration
Public Property XmlText As XmlTextAttribute
'Usage
Dim instance As XmlAttributes
Dim value As XmlTextAttribute
value = instance.XmlText
instance.XmlText = value
public XmlTextAttribute XmlText { get; set; }
public:
property XmlTextAttribute^ XmlText {
XmlTextAttribute^ get ();
void set (XmlTextAttribute^ value);
}
/** @property */
public XmlTextAttribute get_XmlText ()
/** @property */
public void set_XmlText (XmlTextAttribute value)
public function get XmlText () : XmlTextAttribute
public function set XmlText (value : XmlTextAttribute)
Eigenschaftenwert
Ein XmlTextAttribute, das die Standardserialisierung öffentlicher Eigenschaften oder Felder überschreibt.
Hinweise
In der Standardeinstellung wird ein öffentliches Feld oder eine öffentliche Lese-/Schreibeigenschaft von XmlSerializer als XML-Element serialisiert. Sie können jedoch erzwingen, dass das Feld oder die Eigenschaft als XML-Text serialisiert wird, indem Sie dem Feld oder der Eigenschaft ein XmlTextAttribute zuweisen.
Hinweis
Es ist nicht möglich, ein XmlTextAttribute Feldern oder Eigenschaften zuzuweisen, die ein Array zurückgeben.
Erstellen Sie zum Überschreiben der Standardserialisierung von Feldern oder Eigenschaften, die kein Array zurückgeben, ein XmlTextAttribute, und weisen Sie dieses der XmlText-Eigenschaft eines XmlAttributes-Objekts zu. Fügen Sie das XmlAttributes-Objekt einem XmlAttributeOverrides-Objekt hinzu, und geben Sie dabei den Typ des Objekts, das das überschriebene Feld oder die überschriebene Eigenschaft enthält, sowie den Namen des überschriebenen Felds oder der überschriebenen Eigenschaft an.
Beispiel
Im folgenden Beispiel wird die Klasse Group serialisiert, die das Feld Comment enthält. Zum Überschreiben der Standardserialisierung des Felds durch XmlSerializer werden ein XmlAttributeOverrides-Objekt und ein XmlAttributes-Objekt erstellt. Anschließend wird ein XmlTextAttribute-Objekt erstellt und der XmlText-Eigenschaft zugewiesen. Dann wird das XmlAttributes-Objekt mit dem Namen des Felds, das als XML-Text serialisiert werden soll, dem XmlAttributeOverrides-Objekt zugewiesen. Abschließend wird ein XmlSerializer mithilfe des XmlAttributeOverrides-Objekts erstellt.
Imports System
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
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);
}
}
#using <System.Xml.dll>
#using <System.dll>
using namespace System;
using namespace System::IO;
using namespace System::Xml;
using namespace System::Xml::Serialization;
// This is the class that will be serialized.
public ref class Group
{
public:
String^ GroupName;
// This field will be serialized as XML text.
String^ Comment;
};
// Return an XmlSerializer to be used for overriding.
XmlSerializer^ CreateOverrider()
{
// Create the XmlAttributeOverrides and XmlAttributes objects.
XmlAttributeOverrides^ xOver = gcnew XmlAttributeOverrides;
XmlAttributes^ xAttrs = gcnew 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 = gcnew XmlTextAttribute;
xAttrs->XmlText = xText;
xOver->Add( Group::typeid, "Comment", xAttrs );
// Create the XmlSerializer, and return it.
return gcnew XmlSerializer( Group::typeid,xOver );
}
void SerializeObject( String^ filename )
{
// Create an instance of the XmlSerializer class.
XmlSerializer^ mySerializer = CreateOverrider();
// Writing the file requires a TextWriter.
TextWriter^ writer = gcnew StreamWriter( filename );
// Create an instance of the class that will be serialized.
Group^ myGroup = gcnew 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();
}
void DeserializeObject( String^ filename )
{
XmlSerializer^ mySerializer = CreateOverrider();
FileStream^ fs = gcnew FileStream( filename,FileMode::Open );
Group^ myGroup = dynamic_cast<Group^>(mySerializer->Deserialize( fs ));
Console::WriteLine( myGroup->GroupName );
Console::WriteLine( myGroup->Comment );
}
int main()
{
SerializeObject( "OverrideText.xml" );
DeserializeObject( "OverrideText.xml" );
}
import System.*;
import System.IO.*;
import System.Xml.*;
import 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;
} //Group
public class Run
{
public static void main(String[] args)
{
Run test = new Run();
test.SerializeObject("OverrideText.xml");
test.DeserializeObject("OverrideText.xml");
} //main
// 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.set_XmlText(xText);
xOver.Add(Group.class.ToType(), "Comment", xAttrs);
// Create the XmlSerializer, and return it.
return new XmlSerializer(Group.class.ToType(), xOver);
} //CreateOverrider
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();
} //SerializeObject
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);
} //DeserializeObject
} //Run
Plattformen
Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile für Pocket PC, Windows Mobile für Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
.NET Framework unterstützt nicht alle Versionen sämtlicher Plattformen. Eine Liste der unterstützten Versionen finden Sie unter Systemanforderungen.
Versionsinformationen
.NET Framework
Unterstützt in: 2.0, 1.1, 1.0
.NET Compact Framework
Unterstützt in: 2.0
Siehe auch
Referenz
XmlAttributes-Klasse
XmlAttributes-Member
System.Xml.Serialization-Namespace