CompositeNode class

CompositeNode class

Base class for nodes that can contain other nodes. To learn more, visit the Aspose.Words Document Object Model (DOM) documentation article.

Remarks

A document is represented as a tree of nodes, similar to DOM or XmlDocument.

For more info see the Composite design pattern.

The CompositeNode class:

  • Provides access to the child nodes.

  • Implements Composite operations such as insert and remove children.

  • Provides methods for XPath navigation.

Inheritance: CompositeNodeNode

Properties

NameDescription
countGets the number of immediate children of this node.
customNodeIdSpecifies custom node identifier.
(Inherited from Node)
documentGets the document to which this node belongs.
(Inherited from Node)
firstChildGets the first child of the node.
hasChildNodesReturns true if this node has any child nodes.
isCompositeReturns true as this node can have child nodes.
lastChildGets the last child of the node.
nextSiblingGets the node immediately following this node.
(Inherited from Node)
nodeTypeGets the type of this node.
(Inherited from Node)
parentNodeGets the immediate parent of this node.
(Inherited from Node)
previousSiblingGets the node immediately preceding this node.
(Inherited from Node)
rangeReturns a Range object that represents the portion of a document that is contained in this node.
(Inherited from Node)

Methods

NameDescription
appendChild(newChild)Adds the specified node to the end of the list of child nodes for this node.
asBody()Cast node to Body.
(Inherited from Node)
asBookmarkEnd()Cast node to BookmarkEnd.
(Inherited from Node)
asBookmarkStart()Cast node to BookmarkStart.
(Inherited from Node)
asBuildingBlock()Cast node to BuildingBlock.
(Inherited from Node)
asCell()Cast node to Cell.
(Inherited from Node)
asComment()Cast node to Comment.
(Inherited from Node)
asCommentRangeEnd()Cast node to CommentRangeEnd.
(Inherited from Node)
asCommentRangeStart()Cast node to CommentRangeStart.
(Inherited from Node)
asCompositeNode()Cast node to CompositeNode.
(Inherited from Node)
asDocument()Cast node to Node.document.
(Inherited from Node)
asEditableRangeEnd()Cast node to EditableRangeEnd.
(Inherited from Node)
asEditableRangeStart()Cast node to EditableRangeStart.
(Inherited from Node)
asFieldEnd()Cast node to FieldEnd.
(Inherited from Node)
asFieldSeparator()Cast node to FieldSeparator.
(Inherited from Node)
asFieldStart()Cast node to FieldStart.
(Inherited from Node)
asFootnote()Cast node to Footnote.
(Inherited from Node)
asFormField()Cast node to FormField.
(Inherited from Node)
asGlossaryDocument()Cast node to GlossaryDocument.
(Inherited from Node)
asGroupShape()Cast node to GroupShape.
(Inherited from Node)
asHeaderFooter()Cast node to HeaderFooter.
(Inherited from Node)
asOfficeMath()Cast node to OfficeMath.
(Inherited from Node)
asParagraph()Cast node to Paragraph.
(Inherited from Node)
asRow()Cast node to Row.
(Inherited from Node)
asRun()Cast node to Run.
(Inherited from Node)
asSection()Cast node to Section.
(Inherited from Node)
asShape()Cast node to Shape.
(Inherited from Node)
asSmartTag()Cast node to SmartTag.
(Inherited from Node)
asSpecialChar()Cast node to SpecialChar.
(Inherited from Node)
asStructuredDocumentTag()Cast node to StructuredDocumentTag.
(Inherited from Node)
asStructuredDocumentTagRangeEnd()Cast node to StructuredDocumentTagRangeEnd.
(Inherited from Node)
asStructuredDocumentTagRangeStart()Cast node to StructuredDocumentTagRangeStart.
(Inherited from Node)
asSubDocument()Cast node to SubDocument.
(Inherited from Node)
asTable()Cast node to Table.
(Inherited from Node)
clone(isCloneChildren)Creates a duplicate of the node.
(Inherited from Node)
getAncestor(ancestorType)Gets the first ancestor of the specified NodeType.
(Inherited from Node)
getBuildingBlock(index, isDeep)Returns an Nth child BuildingBlock node.
getChild(nodeType, index, isDeep)Returns an Nth child node that matches the specified type.
getChildNodes(nodeType, isDeep)Returns a live collection of child nodes that match the specified type.
getComment(index, isDeep)Returns an Nth child Comment node.
getEditableRangeStart(index, isDeep)Returns an Nth child EditableRangeStart node.
getFootnote(index, isDeep)Returns an Nth child Footnote node.
getGroupShape(index, isDeep)Returns an Nth child GroupShape node.
getOfficeMath(index, isDeep)Returns an Nth child OfficeMath node.
getParagraph(index, isDeep)Returns an Nth child Paragraph node.
getRun(index, isDeep)Returns an Nth child Run node.
getSdt(index, isDeep)Returns an Nth child StructuredDocumentTag node.
getSdtRangeEnd(index, isDeep)Returns an Nth child StructuredDocumentTagRangeEnd node.
getSdtRangeStart(index, isDeep)Returns an Nth child StructuredDocumentTagRangeStart node.
getShape(index, isDeep)Returns an Nth child Shape node.
getSmartTag(index, isDeep)Returns an Nth child SmartTag node.
getTable(index, isDeep)Returns an Nth child Table node.
getText()Gets the text of this node and of all its children.
indexOf(child)Returns the index of the specified child node in the child node array.
insertAfter(newChild, refChild)Inserts the specified node immediately after the specified reference node.
insertBefore(newChild, refChild)Inserts the specified node immediately before the specified reference node.
nextPreOrder(rootNode)Gets next node according to the pre-order tree traversal algorithm.
(Inherited from Node)
nodeTypeToString(nodeType)A utility method that converts a node type enum value into a user friendly string.
(Inherited from Node)
prependChild(newChild)Adds the specified node to the beginning of the list of child nodes for this node.
previousPreOrder(rootNode)Gets the previous node according to the pre-order tree traversal algorithm.
(Inherited from Node)
referenceEquals(other)
(Inherited from Node)
remove()Removes itself from the parent.
(Inherited from Node)
removeAllChildren()Removes all the child nodes of the current node.
removeChild(oldChild)Removes the specified child node.
removeSmartTags()Removes all SmartTag descendant nodes of the current node.
selectNodes(xpath)Selects a list of nodes matching the XPath expression.
selectSingleNode(xpath)Selects the first Node that matches the XPath expression.
toString(saveFormat)Exports the content of the node into a string in the specified format.
(Inherited from Node)
toString(saveOptions)Exports the content of the node into a string using the specified save options.
(Inherited from Node)

Examples

Shows how to traverse through a composite node’s collection of child nodes.

let doc = new aw.Document();

// Add two runs and one shape as child nodes to the first paragraph of this document.
let paragraph = doc.getParagraph(0, true);
paragraph.appendChild(new aw.Run(doc, "Hello world! "));

let shape = new aw.Drawing.Shape(doc, aw.Drawing.ShapeType.Rectangle);
shape.width = 200;
shape.height = 200;
// Note that the 'CustomNodeId' is not saved to an output file and exists only during the node lifetime.
shape.customNodeId = 100;
shape.wrapType = aw.Drawing.WrapType.Inline;
paragraph.appendChild(shape);

paragraph.appendChild(new aw.Run(doc, "Hello again!"));

// Iterate through the paragraph's collection of immediate children,
// and print any runs or shapes that we find within.
let children = paragraph.getChildNodes(aw.NodeType.Any, false);

expect(paragraph.getChildNodes(aw.NodeType.Any, false).count).toEqual(3);

for (let child of children)
  switch (child.nodeType)
  {
    case aw.NodeType.Run:
      console.log("Run contents:");
      console.log(`\t\"${child.getText().trim()}\"`);
      break;
    case aw.NodeType.Shape:
      let childShape = child.asShape();
      console.log("Shape:");
      console.log(`\t${childShape.shapeType}, ${childShape.width}x${childShape.height}`);
      expect(shape.customNodeId).toEqual(100);
      break;
  }

See Also