XContainer.Nodes Method

Definition

Devuelve una colección de los nodos secundarios de este elemento o documento, clasificados por documento.Returns a collection of the child nodes of this element or document, in document order.

public:
 System::Collections::Generic::IEnumerable<System::Xml::Linq::XNode ^> ^ Nodes();
public System.Collections.Generic.IEnumerable<System.Xml.Linq.XNode> Nodes ();
member this.Nodes : unit -> seq<System.Xml.Linq.XNode>
Public Function Nodes () As IEnumerable(Of XNode)
Public Iterator Function Nodes () As IEnumerable(Of XNode)

Returns

IEnumerable<XNode>

Interfaz IEnumerable<T> de XNode que incluye el contenido de XContainer, clasificado por documento.An IEnumerable<T> of XNode containing the contents of this XContainer, in document order.

Examples

En el ejemplo siguiente se crea un árbol XML con varios tipos de nodos.The following example creates an XML tree with a variety of types of nodes. A continuación, consulta este método de eje para enumerar e imprimir los nodos.It then queries this axis method to enumerate and print the nodes.

XElement xmlTree = new XElement("Root",  
    new XElement("Child1", 1),  
    new XElement("Child2", 2),  
    new XComment("a comment"),  
    new XElement("Child3", 3),  
    new XElement("Child4", 4),  
    new XText("mixed content"),  
    new XElement("Child5", 5)  
);  
IEnumerable<XNode> nodes =  
    from nd in xmlTree.Nodes()  
    select nd;  
foreach (XNode node in nodes)  
    Console.WriteLine(node);  
Dim xmlTree As XElement = _   
        <Root>  
            <Child1>1</Child1>  
            <Child2>2</Child2>  
            <!--a comment-->  
            <Child3>3</Child3>  
            <Child4>4</Child4>mixed content<Child5>5</Child5>  
            </Root>  
  
Dim nodes = From nd In xmlTree.Nodes() _  
            Select nd  
  
For Each node In nodes  
    Console.WriteLine(node)  
Next  

En este ejemplo se produce la siguiente salida:This example produces the following output:

<Child1>1</Child1>  
<Child2>2</Child2>  
<!--a comment-->  
<Child3>3</Child3>  
<Child4>4</Child4>  
mixed content  
<Child5>5</Child5>  

En el ejemplo siguiente se crea un árbol XML que contiene varios tipos de nodos.The following example creates an XML tree that contains a variety of types of nodes. A continuación, se enumeran las partes del árbol y se imprimen los tipos de nodo.It then enumerates through portions of the tree, printing the node types.

XDocument xmlTree = new XDocument(  
    new XComment("a comment"),  
    new XProcessingInstruction("xml-stylesheet", "type=\"text/xsl\" href=\"hello.xsl\""),  
    new XElement("Root",  
        new XAttribute("Att", "attContent"),  
        new XElement("Child1",  
            new XCData("CDATA content")  
        ),  
        new XElement("Child2",  
            new XText("Text content")  
        )  
    )  
);  
  
foreach (XNode node in xmlTree.Nodes())  
{  
    Console.WriteLine(node.NodeType);  
    if (node.NodeType == XmlNodeType.Element)  
    {  
        foreach (XAttribute att in ((XElement)node).Attributes())  
            Console.WriteLine(att.NodeType);  
        foreach (XNode node2 in ((XElement)node).Nodes())  
        {  
            Console.WriteLine(node2.NodeType);  
            if (node2.NodeType == XmlNodeType.Element)  
                foreach (XNode node3 in ((XElement)node2).Nodes())  
                    Console.WriteLine(node3.NodeType);  
        }  
    }  
}  
Dim xmlTree As XDocument = _   
    <?xml version="1.0" encoding="utf-8"?>  
    <!--a comment-->  
    <?xml-stylesheet type='text/xsl' href='hello.xsl'?>  
    <Root Att="attContent">  
        <Child1><![CDATA[CDATA content]

Remarks

Tenga en cuenta que el contenido no incluye atributos.Note that the content does not include attributes. En LINQ to XMLLINQ to XML, los atributos no se consideran nodos del árbol.In LINQ to XMLLINQ to XML, attributes are not considered to be nodes of the tree. Son pares de nombre y valor asociados a un elemento.They are name/value pairs associated with an element.

Este método usa la ejecución diferida.This method uses deferred execution.

Applies to

See also