Extensions.InDocumentOrder<T>(IEnumerable<T>) Méthode

Définition

Retourne une collection de nœuds qui contient tous les nœuds de la collection source, triés selon l'ordre des documents.

C#
public static System.Collections.Generic.IEnumerable<T> InDocumentOrder<T> (this System.Collections.Generic.IEnumerable<T> source) where T : System.Xml.Linq.XNode;

Paramètres de type

T

Type des objets de source, contraint par XNode.

Paramètres

source
IEnumerable<T>

IEnumerable<T> de XNode qui contient la collection source.

Retours

IEnumerable<T>

IEnumerable<T> de XNode qui contient tous les nœuds de la collection source, triés selon l'ordre des documents.

Exemples

L’exemple suivant crée une collection de nœuds qui ne sont pas dans l’ordre du document, puis utilise cet axe pour créer une collection où les nœuds sont dans l’ordre du document.

C#
XElement xmlTree = new XElement("Root",  
    new XElement("Item",  
        new XElement("aaa", 1),  
        new XElement("bbb", 2)  
    ),  
    new XElement("Item",  
        new XElement("ccc", 3),  
        new XElement("aaa", 4)  
    ),  
    new XElement("Item",  
        new XElement("ddd", 5),  
        new XElement("eee", 6)  
    )  
);  

XElement[] elementList = {  
    xmlTree.Descendants("ddd").First(),  
    xmlTree.Descendants("ccc").First(),  
    xmlTree.Descendants("aaa").First()  
};  

IEnumerable<XElement> inDocOrder = elementList.InDocumentOrder();  

foreach (XElement el in inDocOrder)  
    Console.WriteLine(el);  

Cet exemple produit la sortie suivante :

<aaa>1</aaa>  
<ccc>3</ccc>  
<ddd>5</ddd>  

Remarques

Cette méthode d’axe utilise l’exécution différée. Toutefois, elle énumère d’abord sa collection source, trie les nœuds dans l’ordre des documents, puis génère les résultats.

S’applique à

Produit Versions
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Voir aussi