先简单描述XML文件的结构如何。
XML文件中,“元素(Element)”是其基本结构,整个XML文件就是由若干“元素(Element)”组成的。
下面是一个元素的例子:
<T Name="Sample">This is Sample</T>
整个这一串字符称为“元素(Element)”,它由几部分组成。T称为“元素(Element)”的“标签(Tag)”。一个“元素(Element)”包含开始标签<T>和结束标签</T>。标签内包含“文本(Text)”,本例是This is Sample字符串;或者包含子元素(也就是元素的嵌套)。而Name="Sample"称为“元素(Element)”的“属性(Attribute)”,不过“属性(Attribute)”不是“元素(Element)”的必须的部分,可以没有,可以有若干个。
XML文件就是由若干个“元素(Element)”组成的。不过只能有一个“根元素(Root)”,其他的元素都是“根元素(Root)”的子元素,或者是子元素的子元素。
Xml.Serialization序列化一个对象,就是把对象序列化成一个XML的“元素(Element)”。如果一个类没有加任何的特性,那么默认的话,这个类序列化后的“标签(Tag)”就是这个类的类名,这个类的公共字段和公共属性都被序列化
成子元素,子元素的“标签(Tag)”就是字段名(或者是属性名),子元素的“文本(Text)”就是字段值(或者是属性值)。
通过Xml.Serialization中的一些类,可以给一个类添加一些特性,使得在序列化的时候,能够实现自己的定制。
XmlRoot("Settings"),这个表明把类序列化成“根元素(Root)”,“根元素(Root)”的“标签(Tag)”是Settings而不是原来的类名。注意,一个XML文件中只能有一个“根元素(Root)”。
XmlElement("T"),这个表明把类或者是字段(属性)序列化成“元素(Element)”,元素的“标签(Tag)”是T,而不是原来的类名(字段名或者是属性名)。
XmlAttribute("Count"),这个表明把字段(属性)序列化成“属性(Attribute)”,属性名就是字段(属性)名,属性值就是字段(属性)值。这个似乎不能运用在数组字段(属性)。
XmlText,这个表明把字段(属性)序列化成“文本(Text)”,文本值就是字段(属性)值。不过,一个类中,只能有一个字段(属性)序列化成“文本(Text)”,而且这个类序列化后的元素还不能有子元素,意味着这个类的其他字段(属性)只能序列化成“属性(Attribute)”。
XmlIgnore,这个表明不序列化指定的字段(属性)。
除了以上的,在遇到集合类型的字段(属性)时,Xml.Serialization是将该字段(属性)序列化成一个“元素(Element)”,该字段中的每一个对象序列化成该元素的子元素。
对集合类型的字段(属性)可以添加下列特性
XmlArray("E"),这个表明把该字段(属性)序列化成“元素(Element)”,“标签(Tag)”为E。
例如:<XmlArray("E")>Public Student As List(Of String),有三个值A、B、C。
序列化后的结果为:
<E>
<String>A</String>
<String>B</String>
<String>C</String>
</E>
<XmlArrayItem("E")>,这个表明把该字段(属性)每一个对象序列化为“元素(Element)”,“标签(Tag)”为E。
例如:<XmlArrayItem("E")>Public Student As List(Of String),有三个值A、B、C。
序列化后的结果为:
<Student>
<E>A</E>
<E>B</E>
<E>C</E>
</Student>
大家可以和上面的例子对照一下区别。
另外,上面两个特性是可以叠加的。
还可以对集合型的字段(属性)添加XmlElement("E"),它表明将每一个对象序列化为“元素(Element)”,“标签(Tag)”为E,同时每一个对象又都是它的子元素。通俗的讲,就是平行序列化。
例如::<XmlElement("Lan")>Public Student As List(Of String),有三个值A、B、C。
序列化后的结果为:
<E>
<String>A</String>
</E>
<E>
<String>B</String>
</E>
<E>
<String>C</String>
</E>
以上是简单的描述通过Xml.Serialization中的一些类,来控制对象的序列化成XML文件。也希望和各网友交流。