XmlSerializerNamespaces Classe
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
Contiene gli spazi dei nomi XML e i XmlSerializer prefissi utilizzati da per generare nomi qualificati in un'istanza di documento XML.
public ref class XmlSerializerNamespaces
public class XmlSerializerNamespaces
type XmlSerializerNamespaces = class
Public Class XmlSerializerNamespaces
- Ereditarietà
-
XmlSerializerNamespaces
Esempio
Nell'esempio seguente viene creato un XmlSerializerNamespaces oggetto e vengono aggiunte due coppie di prefisso e spazio dei nomi. Nell'esempio XmlSerializerNamespaces viene quindi passato al Serialize metodo , che serializza un Books oggetto in un documento XML. Usando l'oggetto XmlSerializerNamespaces , il Serialize metodo qualifica ogni elemento XML e attributo con uno dei due spazi dei nomi.
using System;
using System.IO;
using System.Xml;
using System.Xml.Serialization;
public class Run
{
public static void Main()
{
Run test = new Run();
test.SerializeObject("XmlNamespaces.xml");
}
public void SerializeObject(string filename)
{
XmlSerializer s = new XmlSerializer(typeof(Books));
// Writing a file requires a TextWriter.
TextWriter t = new StreamWriter(filename);
/* Create an XmlSerializerNamespaces object and add two
prefix-namespace pairs. */
XmlSerializerNamespaces ns = new XmlSerializerNamespaces();
ns.Add("books", "http://www.cpandl.com");
ns.Add("money", "http://www.cohowinery.com");
// Create a Book instance.
Book b = new Book();
b.TITLE = "A Book Title";
Price p = new Price();
p.price = (decimal) 9.95;
p.currency = "US Dollar";
b.PRICE = p;
Books bks = new Books();
bks.Book = b;
s.Serialize(t,bks,ns);
t.Close();
}
}
public class Books
{
[XmlElement(Namespace = "http://www.cohowinery.com")]
public Book Book;
}
[XmlType(Namespace ="http://www.cpandl.com")]
public class Book
{
[XmlElement(Namespace = "http://www.cpandl.com")]
public string TITLE;
[XmlElement(Namespace ="http://www.cohowinery.com")]
public Price PRICE;
}
public class Price
{
[XmlAttribute(Namespace = "http://www.cpandl.com")]
public string currency;
[XmlElement(Namespace = "http://www.cohowinery.com")]
public decimal price;
}
Imports System.IO
Imports System.Xml
Imports System.Xml.Serialization
Public Class Run
Public Shared Sub Main()
Dim test As New Run()
test.SerializeObject("XmlNamespaces.xml")
End Sub
Public Sub SerializeObject(ByVal filename As String)
Dim s As New XmlSerializer(GetType(Books))
' Writing a file requires a TextWriter.
Dim t As New StreamWriter(filename)
' Create an XmlSerializerNamespaces object and add two
' prefix-namespace pairs.
Dim ns As New XmlSerializerNamespaces()
ns.Add("books", "http://www.cpandl.com")
ns.Add("money", "http://www.cohowinery.com")
' Create a Book instance.
Dim b As New Book()
b.TITLE = "A Book Title"
Dim p As New Price()
p.price = CDec(9.95)
p.currency = "US Dollar"
b.PRICE = p
Dim bks As New Books()
bks.Book = b
s.Serialize(t, bks, ns)
t.Close()
End Sub
End Class
Public Class Books
<XmlElement(Namespace := "http://www.cohowinery.com")> _
Public Book As Book
End Class
<XmlType(Namespace := "http://www.cpandl.com")> _
Public Class Book
<XmlElement(Namespace := "http://www.cpandl.com")> _
Public TITLE As String
<XmlElement(Namespace := "http://www.cohowinery.com")> _
Public PRICE As Price
End Class
Public Class Price
<XmlAttribute(Namespace := "http://www.cpandl.com")> _
Public currency As String
<XmlElement(Namespace := "http://www.cohowinery.com")> _
Public price As Decimal
End Class
Commenti
XmlSerializerNamespaces Contiene una raccolta di spazi dei nomi XML, ognuno con un prefisso associato. XmlSerializer utilizza un'istanza della XmlSerializerNamespaces classe per creare nomi qualificati in un documento XML.
Gli spazi dei nomi XML contenuti da XmlSerializerNamespaces devono essere conformi alla specifica W3C denominata Namespaces in XML.
Gli spazi dei nomi XML consentono di qualificare i nomi di elementi e attributi XML nei documenti XML. Un nome completo è costituito da un prefisso e un nome locale, separati da due punti. Il prefisso funziona solo come segnaposto; viene mappato a un URI che specifica uno spazio dei nomi. La combinazione dello spazio dei nomi URI gestito universalmente e del nome locale produce un nome che è garantito essere univoco universalmente.
Per creare nomi qualificati in un documento XML:
Creare un'istanza XmlSerializerNamespaces.
Add ogni coppia di prefissi e spazi dei nomi che si desidera assegnare all'istanza.
Applicare l'attributo appropriato.NET a ogni proprietà o classe serializzata dal XmlSerializer in un documento XML. Gli attributi disponibili sono:
Impostare la
Namespaceproprietà di ogni attributo su uno dei valori dello spazio dei nomi dell'oggetto XmlSerializerNamespaces .Passare l'oggetto XmlSerializerNamespaces al Serialize metodo dell'oggetto XmlSerializer.
Note
La creazione di uno spazio dei nomi vuoto e una coppia di prefissi non è supportata. Ciò significa che non è possibile creare una coppia usando il codice seguente:
XmlSerializerNamespaces ns = new XmlSerializerNamespaces();
ns.Add("", "");
Dim ns As XmlSerializerNamespaces ns = New XmlSerializerNamespaces()
ns.Add("", "")
Costruttori
| Nome | Descrizione |
|---|---|
| XmlSerializerNamespaces() |
Inizializza una nuova istanza della classe XmlSerializerNamespaces. |
| XmlSerializerNamespaces(XmlQualifiedName[]) |
Inizializza una nuova istanza della classe XmlSerializerNamespaces. |
| XmlSerializerNamespaces(XmlSerializerNamespaces) |
Inizializza una nuova istanza della XmlSerializerNamespaces classe utilizzando l'istanza specificata di |
Proprietà
| Nome | Descrizione |
|---|---|
| Count |
Ottiene il numero di coppie di prefisso e spazio dei nomi nella raccolta. |
Metodi
| Nome | Descrizione |
|---|---|
| Add(String, String) |
Aggiunge un prefisso e una coppia di spazi dei nomi a un XmlSerializerNamespaces oggetto . |
| Equals(Object) |
Determina se l'oggetto specificato è uguale all'oggetto corrente. (Ereditato da Object) |
| GetHashCode() |
Funge da funzione hash predefinita. (Ereditato da Object) |
| GetType() |
Ottiene il Type dell'istanza corrente. (Ereditato da Object) |
| MemberwiseClone() |
Crea una copia superficiale del Objectcorrente. (Ereditato da Object) |
| ToArray() |
Ottiene la matrice di coppie di prefisso e spazio dei nomi in un XmlSerializerNamespaces oggetto . |
| ToString() |
Restituisce una stringa che rappresenta l'oggetto corrente. (Ereditato da Object) |