XmlEnumAttribute 构造函数
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
初始化 XmlEnumAttribute 类的新实例。
重载
XmlEnumAttribute() |
初始化 XmlEnumAttribute 类的新实例。 |
XmlEnumAttribute(String) |
初始化 XmlEnumAttribute 类的新实例,并指定 XmlSerializer 生成或识别的(当该序列化程序分别序列化或反序列化枚举时)XML 值。 |
XmlEnumAttribute()
- Source:
- XmlEnumAttribute.cs
- Source:
- XmlEnumAttribute.cs
- Source:
- XmlEnumAttribute.cs
初始化 XmlEnumAttribute 类的新实例。
public:
XmlEnumAttribute();
public XmlEnumAttribute ();
Public Sub New ()
示例
以下示例序列化名为 和 FoodType
的两个Food
类。 类 FoodType
包含两个被重写的枚举,对于每个枚举,此示例创建一个 XmlEnumAttribute 分配给 XmlEnum 对象的 属性的对象 XmlAttributes 。 然后,该示例将 XmlAttributes 对象添加到 XmlAttributeOverrides 对象,该对象用于创建 XmlSerializer。
#using <System.Xml.dll>
#using <System.dll>
using namespace System;
using namespace System::IO;
using namespace System::Xml;
using namespace System::Xml::Serialization;
public enum class FoodType
{
// Subsequent code overrides these enumerations.
Low, High
};
// This is the class that will be serialized.
public ref class Food
{
public:
FoodType Type;
};
// Return an XmlSerializer used for overriding.
XmlSerializer^ CreateOverrider()
{
// Create the XmlOverrides and XmlAttributes objects.
XmlAttributeOverrides^ xOver = gcnew XmlAttributeOverrides;
XmlAttributes^ xAttrs = gcnew XmlAttributes;
// Add an XmlEnumAttribute for the FoodType.Low enumeration.
XmlEnumAttribute^ xEnum = gcnew XmlEnumAttribute;
xEnum->Name = "Cold";
xAttrs->XmlEnum = xEnum;
xOver->Add( FoodType::typeid, "Low", xAttrs );
// Add an XmlEnumAttribute for the FoodType.High enumeration.
xAttrs = gcnew XmlAttributes;
xEnum = gcnew XmlEnumAttribute;
xEnum->Name = "Hot";
xAttrs->XmlEnum = xEnum;
xOver->Add( FoodType::typeid, "High", xAttrs );
// Create the XmlSerializer, and return it.
return gcnew XmlSerializer( Food::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.
Food^ myFood = gcnew Food;
// Set the object properties.
myFood->Type = FoodType::High;
// Serialize the class, and close the TextWriter.
mySerializer->Serialize( writer, myFood );
writer->Close();
}
void DeserializeObject( String^ filename )
{
XmlSerializer^ mySerializer = CreateOverrider();
FileStream^ fs = gcnew FileStream( filename,FileMode::Open );
Food^ myFood = dynamic_cast<Food^>(mySerializer->Deserialize( fs ));
Console::WriteLine( myFood->Type );
}
int main()
{
SerializeObject( "OverrideEnum.xml" );
DeserializeObject( "OverrideEnum.xml" );
}
using System;
using System.IO;
using System.Xml;
using System.Xml.Serialization;
// This is the class that will be serialized.
public class Food
{
public FoodType Type;
}
public enum FoodType
{
// Subsequent code overrides these enumerations.
Low,
High
}
public class Run
{
public static void Main()
{
Run test = new Run();
test.SerializeObject("OverrideEnum.xml");
test.DeserializeObject("OverrideEnum.xml");
}
// Return an XmlSerializer used for overriding.
public XmlSerializer CreateOverrider()
{
// Create the XmlOverrides and XmlAttributes objects.
XmlAttributeOverrides xOver = new XmlAttributeOverrides();
XmlAttributes xAttrs = new XmlAttributes();
// Add an XmlEnumAttribute for the FoodType.Low enumeration.
XmlEnumAttribute xEnum = new XmlEnumAttribute();
xEnum.Name = "Cold";
xAttrs.XmlEnum = xEnum;
xOver.Add(typeof(FoodType), "Low", xAttrs);
// Add an XmlEnumAttribute for the FoodType.High enumeration.
xAttrs = new XmlAttributes();
xEnum = new XmlEnumAttribute();
xEnum.Name = "Hot";
xAttrs.XmlEnum = xEnum;
xOver.Add(typeof(FoodType), "High", xAttrs);
// Create the XmlSerializer, and return it.
return new XmlSerializer(typeof(Food), 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.
Food myFood = new Food();
// Set the object properties.
myFood.Type = FoodType.High;
// Serialize the class, and close the TextWriter.
mySerializer.Serialize(writer, myFood);
writer.Close();
}
public void DeserializeObject(string filename)
{
XmlSerializer mySerializer = CreateOverrider();
FileStream fs = new FileStream(filename, FileMode.Open);
Food myFood = (Food)
mySerializer.Deserialize(fs);
Console.WriteLine(myFood.Type);
}
}
Imports System.IO
Imports System.Xml
Imports System.Xml.Serialization
' This is the class that will be serialized.
Public Class Food
Public Type As FoodType
End Class
Public Enum FoodType
' Subsequent code overrides these enumerations.
Low
High
End Enum
Public Class Run
Public Shared Sub Main()
Dim test As New Run()
test.SerializeObject("OverrideEnum.xml")
test.DeserializeObject("OverrideEnum.xml")
End Sub
' Return an XmlSerializer used for overriding.
Public Function CreateOverrider() As XmlSerializer
' Create the XmlOverrides and XmlAttributes objects.
Dim xOver As New XmlAttributeOverrides()
Dim xAttrs As New XmlAttributes()
' Add an XmlEnumAttribute for the FoodType.Low enumeration.
Dim xEnum As New XmlEnumAttribute()
xEnum.Name = "Cold"
xAttrs.XmlEnum = xEnum
xOver.Add(GetType(FoodType), "Low", xAttrs)
' Add an XmlEnumAttribute for the FoodType.High enumeration.
xAttrs = New XmlAttributes()
xEnum = New XmlEnumAttribute()
xEnum.Name = "Hot"
xAttrs.XmlEnum = xEnum
xOver.Add(GetType(FoodType), "High", xAttrs)
' Create the XmlSerializer, and return it.
Return New XmlSerializer(GetType(Food), 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 myFood As New Food()
' Set the object properties.
myFood.Type = FoodType.High
' Serialize the class, and close the TextWriter.
mySerializer.Serialize(writer, myFood)
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 myFood As Food = CType(mySerializer.Deserialize(fs), Food)
Console.WriteLine(myFood.Type)
End Sub
End Class
注解
可以使用 XmlEnumAttribute 替代现有枚举。
注意
可以在代码中使用 单词 XmlEnum
,而不是较长 XmlEnumAttribute的 。
另请参阅
适用于
XmlEnumAttribute(String)
- Source:
- XmlEnumAttribute.cs
- Source:
- XmlEnumAttribute.cs
- Source:
- XmlEnumAttribute.cs
初始化 XmlEnumAttribute 类的新实例,并指定 XmlSerializer 生成或识别的(当该序列化程序分别序列化或反序列化枚举时)XML 值。
public:
XmlEnumAttribute(System::String ^ name);
public XmlEnumAttribute (string name);
public XmlEnumAttribute (string? name);
new System.Xml.Serialization.XmlEnumAttribute : string -> System.Xml.Serialization.XmlEnumAttribute
Public Sub New (name As String)
参数
- name
- String
该枚举成员的重写名。
示例
以下示例将 应用于 XmlEnumAttribute 枚举的成员。 XmlSerializer当 为此枚举生成 XML 数据时,数据符合属性的值Name。
public enum class EmployeeStatus
{
[XmlEnum("Single")]
One,
[XmlEnum("Double")]
Two,
[XmlEnum("Triple")]
Three
};
public enum EmployeeStatus
{
[XmlEnum("Single")]
One,
[XmlEnum("Double")]
Two,
[XmlEnum("Triple")]
Three
}
Public Enum EmployeeStatus
<XmlEnumAttribute("Single")> One
<XmlEnumAttribute("Double")> Two
<XmlEnumAttribute("Triple")> Three
End Enum
注解
注意
可以在代码中使用 单词 XmlEnum
,而不是较长 XmlEnumAttribute的 。