FirstChild
Contents
[
Hide
]CompositeNode.FirstChild property
Gets the first child of the node.
public Node FirstChild { get; }
Remarks
If there is no first child node, a null
is returned.
Examples
Shows how to use a node’s NextSibling property to enumerate through its immediate children.
Document doc = new Document(MyDir + "Paragraphs.docx");
for (Node node = doc.FirstSection.Body.FirstChild; node != null; node = node.NextSibling)
{
Console.WriteLine();
Console.WriteLine($"Node type: {Node.NodeTypeToString(node.NodeType)}");
string contents = node.GetText().Trim();
Console.WriteLine(contents == string.Empty ? "This node contains no text" : $"Contents: \"{node.GetText().Trim()}\"");
}
Shows how to traverse a composite node’s tree of child nodes.
public void RecurseChildren()
{
Document doc = new Document(MyDir + "Paragraphs.docx");
// Any node that can contain child nodes, such as the document itself, is composite.
Assert.True(doc.IsComposite);
// Invoke the recursive function that will go through and print all the child nodes of a composite node.
TraverseAllNodes(doc, 0);
}
/// <summary>
/// Recursively traverses a node tree while printing the type of each node
/// with an indent depending on depth as well as the contents of all inline nodes.
/// </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)}");
// Recurse into the node if it is a composite node. Otherwise, print its contents if it is an inline node.
if (childNode.IsComposite)
{
Console.WriteLine();
TraverseAllNodes((CompositeNode)childNode, depth + 1);
}
else if (childNode is Inline)
{
Console.WriteLine($" - \"{childNode.GetText().Trim()}\"");
}
else
{
Console.WriteLine();
}
}
}
See Also
- class Node
- class CompositeNode
- namespace Aspose.Words
- assembly Aspose.Words