IsComposite
Inhalt
[
Ausblenden
]Node.IsComposite property
Gibt zurückWAHR
ob dieser Knoten andere Knoten enthalten kann.
public virtual bool IsComposite { get; }
Eigentumswert
Diese Methode gibt zurückFALSCH
alsNode
kann keine untergeordneten Knoten haben.
Beispiele
Zeigt, wie der Baum der untergeordneten Knoten eines zusammengesetzten Knotens durchlaufen wird.
public void RecurseChildren()
{
Document doc = new Document(MyDir + "Paragraphs.docx");
// Jeder Knoten, der untergeordnete Knoten enthalten kann, z. B. das Dokument selbst, ist zusammengesetzt.
Assert.True(doc.IsComposite);
// Rufen Sie die rekursive Funktion auf, die alle untergeordneten Knoten eines zusammengesetzten Knotens durchläuft und ausgibt.
TraverseAllNodes(doc, 0);
}
/// <summary>
/// Durchläuft rekursiv einen Knotenbaum und gibt dabei den Typ jedes Knotens aus
/// mit einem Einzug abhängig von der Tiefe sowie dem Inhalt aller Inline-Knoten.
/// </summary>
public void TraverseAllNodes(CompositeNode parentNode, int depth)
{
for (Node childNode = parentNode.FirstChild; childNode != null; childNode = childNode.NextSibling)
{
Console.Write($"{new string('\t', depth)}{Node.NodeTypeToString(childNode.NodeType)}");
// Rekursion in den Knoten, wenn es sich um einen zusammengesetzten Knoten handelt. Andernfalls drucken Sie den Inhalt aus, wenn es sich um einen Inline-Knoten handelt.
if (childNode.IsComposite)
{
Console.WriteLine();
TraverseAllNodes((CompositeNode)childNode, depth + 1);
}
else if (childNode is Inline)
{
Console.WriteLine($" - \"{childNode.GetText().Trim()}\"");
}
else
{
Console.WriteLine();
}
}
}
Siehe auch
- class Node
- namensraum Aspose.Words
- Montage Aspose.Words