FirstChild
Contenuti
[
Nascondere
]CompositeNode.FirstChild property
Ottiene il primo figlio del nodo.
public Node FirstChild { get; }
Osservazioni
Se non è presente alcun primo nodo figlio, anullo
viene restituito.
Esempi
Mostra come utilizzare la proprietà NextSibling di un nodo per enumerare i relativi figli immediati.
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()}\"");
}
Mostra come attraversare l’albero dei nodi figlio di un nodo composito.
public void RecurseChildren()
{
Document doc = new Document(MyDir + "Paragraphs.docx");
// Qualsiasi nodo che può contenere nodi secondari, come il documento stesso, è composito.
Assert.True(doc.IsComposite);
// Richiama la funzione ricorsiva che esaminerà e stamperà tutti i nodi figli di un nodo composito.
TraverseAllNodes(doc, 0);
}
/// <summary>
/// Attraversa ricorsivamente un albero di nodi durante la stampa del tipo di ciascun nodo
/// con un rientro che dipende dalla profondità e dal contenuto di tutti i nodi in linea.
/// </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)}");
// Ricorsione nel nodo se è un nodo composito. Altrimenti, stampa il suo contenuto se è un nodo in linea.
if (childNode.IsComposite)
{
Console.WriteLine();
TraverseAllNodes((CompositeNode)childNode, depth + 1);
}
else if (childNode is Inline)
{
Console.WriteLine($" - \"{childNode.GetText().Trim()}\"");
}
else
{
Console.WriteLine();
}
}
}
Guarda anche
- class Node
- class CompositeNode
- spazio dei nomi Aspose.Words
- assemblea Aspose.Words