XContainer.DescendantNodes Método

Definição

Devolve uma coleção dos nós descendentes deste documento ou elemento, por ordem do documento.

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

Devoluções

Um IEnumerable<T> de XNode contendo os nós descendentes do XContainer, por ordem de documento.

Exemplos

O exemplo seguinte cria uma árvore XML e depois itera através do DescendantNodes eixo.

XElement xmlTree = new XElement("Root",
    // Attributes are not nodes, so will not be returned by DescendantNodes.
    new XAttribute("Att1", "AttributeContent"),
    new XElement("Child",
        new XElement("GrandChild", "element content")
    )
);
IEnumerable<XNode> dnas =
    from node in xmlTree.DescendantNodes()
    select node;
foreach (XNode node in dnas)
{
    if (node is XElement)
        Console.WriteLine((node as XElement).Name);
    else
        Console.WriteLine(node);
}
' Attributes are not nodes, so will not be returned by DescendantNodes.
Dim xmlTree As XElement = _
    <Root Att1="AttributeContent">
        <Child>
            <GrandChild>element content</GrandChild>
        </Child>
    </Root>

Dim dnas = From node In xmlTree.DescendantNodes _
           Select node

For Each node In dnas
    If TypeOf node Is XElement Then
        Console.WriteLine(DirectCast(node, XElement).Name)
    Else
        Console.WriteLine(node)
    End If
Next

Este exemplo produz a seguinte saída:

Child
GrandChild
element content

Observações

Note que os atributos não são considerados nós no LINQ para XML, pelo que não farão parte da coleção devolvida por este método.

Este método utiliza execução diferida.

Aplica-se a

Ver também