Serializowanie za pomocą deklaracji XML (LINQ to XML)
W tym artykule opisano sposób kontrolowania, czy deklaracja XML jest generowana podczas serializacji xml w języku C# lub Visual Basic.
Serializowanie do klasy File lub TextWriter przy użyciu XElement.Save metody lub XDocument.Save metody generuje deklarację XML. Podczas serializacji do XmlWriterobiektu ustawienia składnika zapisywania (określone w XmlWriterSettings obiekcie) określają, czy jest generowana deklaracja XML.
Jeśli serializujesz ciąg przy użyciu ToString
metody , wynikowy kod XML nie będzie zawierać deklaracji XML.
Przykład: serializowanie za pomocą deklaracji XML
Poniższy przykład tworzy plik XElement, zapisuje dokument w pliku, a następnie drukuje go w konsoli programu :
XElement root = new XElement("Root",
new XElement("Child", "child content")
);
root.Save("Root.xml");
string str = File.ReadAllText("Root.xml");
Console.WriteLine(str);
Dim root As XElement = <Root>
<Child>child content</Child>
</Root>
root.Save("Root.xml")
Dim str As String = File.ReadAllText("Root.xml")
Console.WriteLine(str)
Ten przykład generuje następujące wyniki:
<?xml version="1.0" encoding="utf-8"?>
<Root>
<Child>child content</Child>
</Root>
Przykład: serializowanie bez deklaracji XML
W poniższym przykładzie pokazano, jak zapisać element XElement w obiekcie XmlWriter.
StringBuilder sb = new StringBuilder();
XmlWriterSettings xws = new XmlWriterSettings();
xws.OmitXmlDeclaration = true;
using (XmlWriter xw = XmlWriter.Create(sb, xws)) {
XElement root = new XElement("Root",
new XElement("Child", "child content")
);
root.Save(xw);
}
Console.WriteLine(sb.ToString());
Dim sb As StringBuilder = New StringBuilder()
Dim xws As XmlWriterSettings = New XmlWriterSettings()
xws.OmitXmlDeclaration = True
Using xw As XmlWriter = XmlWriter.Create(sb, xws)
Dim root = <Root>
<Child>child content</Child>
</Root>
root.Save(xw)
End Using
Console.WriteLine(sb.ToString())
Ten przykład generuje następujące wyniki:
<Root><Child>child content</Child></Root>