Auf Englisch lesen

Teilen über


XNode.PreviousNode Eigenschaft

Definition

Ruft den vorherigen nebengeordneten Knoten dieses Knotens ab.

C#
public System.Xml.Linq.XNode PreviousNode { get; }
C#
public System.Xml.Linq.XNode? PreviousNode { get; }

Eigenschaftswert

Der XNode, der den vorherigen nebengeordneten Knoten enthält.

Beispiele

Im folgenden Beispiel wird diese Eigenschaft zum Durchlaufen von Knoten verwendet.

C#
XElement xmlTree = new XElement("Root",  
    new XElement("Child1", 1),  
    new XText("Some Text"),  
    new XElement("Child2",  
        2,  
        new XElement("GrandChild", "GrandChild Content")  
    ),  
    new XComment("a comment"),  
    new XElement("Child3")  
);  
XNode node = xmlTree.Element("Child2");  
do {  
    StringBuilder sb = new StringBuilder();  
    sb.Append(String.Format("NodeType: {0}", node.NodeType.ToString().PadRight(10)));  
    switch (node.NodeType)  
    {  
        case XmlNodeType.Text:  
            sb.Append((node as XText).Value);  
            break;  
        case XmlNodeType.Element:  
            sb.Append((node as XElement).Name);  
            break;  
        case XmlNodeType.Comment:  
            sb.Append((node as XComment).Value);  
            break;  
    }  
    Console.WriteLine(sb.ToString());  
}  
while ((node = node.PreviousNode) != null);  

Dieses Beispiel erzeugt die folgende Ausgabe:

NodeType: Element   Child2  
NodeType: Text      Some Text  
NodeType: Element   Child1  

Hinweise

Wenn diese XNode kein übergeordnetes Element aufweist oder kein vorheriger Knoten vorhanden ist, gibt diese Eigenschaft zurück null.

Der XContainer speichert seine untergeordneten Knoten als eine singlich verknüpfte Liste von XNode Objekten. Dies bedeutet, dass die PreviousNode -Eigenschaft die Liste der direkten untergeordneten Knoten unter dem übergeordneten Container durchlaufen muss. Daher kann sich die Verwendung dieser Eigenschaft auf Ihre Leistung auswirken.

Gilt für:

Produkt Versionen
.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, 8, 9, 10
.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, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Weitere Informationen