Section class

Section class

Represents a single section in a document. To learn more, visit the Working with Sections documentation article.

Remarks

Section can have one Body and maximum one HeaderFooter of each HeaderFooterType. Body and HeaderFooter nodes can be in any order inside Section.

A minimal valid section needs to have Body with one Paragraph.

Each section has its own set of properties that specify page size, orientation, margins etc.

You can create a copy of a section using Node.clone(). The copy can be inserted into the same or different document.

To add, insert or remove a whole section including section break and section properties use methods of the Document.sections object.

To copy and insert just content of the section excluding the section break and section properties use Section.appendContent() and Section.prependContent() methods.

Inheritance: SectionCompositeNodeNode

Constructors

NameDescription
Section(doc)Initializes a new instance of the Section class.

Properties

NameDescription
bodyReturns the Body child node of the section.
countGets the number of immediate children of this node.
(Inherited from CompositeNode)
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.
(Inherited from CompositeNode)
hasChildNodesReturns true if this node has any child nodes.
(Inherited from CompositeNode)
headersFootersProvides access to the headers and footers nodes of the section.
isCompositeReturns true if this node can contain other nodes.
(Inherited from Node)
lastChildGets the last child of the node.
(Inherited from CompositeNode)
nextSiblingGets the node immediately following this node.
(Inherited from Node)
nodeTypeReturns NodeType.Section.
pageSetupReturns an object that represents page setup and section properties.
parentNodeGets the immediate parent of this node.
(Inherited from Node)
previousSiblingGets the node immediately preceding this node.
(Inherited from Node)
protectedForFormsTrue if the section is protected for forms. When a section is protected for forms, users can select and modify text only in form fields in Microsoft Word.
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.
(Inherited from CompositeNode)
appendContent(sourceSection)Inserts a copy of content of the source section at the end of this section.
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)
clearContent()Clears the section.
clearHeadersFooters()Clears the headers and footers of this section.
clearHeadersFooters(preserveWatermarks)Clears the headers and footers of this section.
clone()Creates a duplicate of this section.
deleteHeaderFooterShapes()Deletes all shapes (drawing objects) from the headers and footers of this section.
ensureMinimum()Ensures that the section has Section.body with one Paragraph.
getAncestor(ancestorType)Gets the first ancestor of the specified NodeType.
(Inherited from Node)
getBuildingBlock(index, isDeep)Returns an Nth child BuildingBlock node.
(Inherited from CompositeNode)
getChild(nodeType, index, isDeep)Returns an Nth child node that matches the specified type.
(Inherited from CompositeNode)
getChildNodes(nodeType, isDeep)Returns a live collection of child nodes that match the specified type.
(Inherited from CompositeNode)
getComment(index, isDeep)Returns an Nth child Comment node.
(Inherited from CompositeNode)
getEditableRangeStart(index, isDeep)Returns an Nth child EditableRangeStart node.
(Inherited from CompositeNode)
getFootnote(index, isDeep)Returns an Nth child Footnote node.
(Inherited from CompositeNode)
getGroupShape(index, isDeep)Returns an Nth child GroupShape node.
(Inherited from CompositeNode)
getOfficeMath(index, isDeep)Returns an Nth child OfficeMath node.
(Inherited from CompositeNode)
getParagraph(index, isDeep)Returns an Nth child Paragraph node.
(Inherited from CompositeNode)
getRun(index, isDeep)Returns an Nth child Run node.
(Inherited from CompositeNode)
getSdt(index, isDeep)Returns an Nth child StructuredDocumentTag node.
(Inherited from CompositeNode)
getSdtRangeEnd(index, isDeep)Returns an Nth child StructuredDocumentTagRangeEnd node.
(Inherited from CompositeNode)
getSdtRangeStart(index, isDeep)Returns an Nth child StructuredDocumentTagRangeStart node.
(Inherited from CompositeNode)
getShape(index, isDeep)Returns an Nth child Shape node.
(Inherited from CompositeNode)
getSmartTag(index, isDeep)Returns an Nth child SmartTag node.
(Inherited from CompositeNode)
getTable(index, isDeep)Returns an Nth child Table node.
(Inherited from CompositeNode)
getText()Gets the text of this node and of all its children.
(Inherited from Node)
indexOf(child)Returns the index of the specified child node in the child node array.
(Inherited from CompositeNode)
insertAfter(newChild, refChild)Inserts the specified node immediately after the specified reference node.
(Inherited from CompositeNode)
insertBefore(newChild, refChild)Inserts the specified node immediately before the specified reference node.
(Inherited from CompositeNode)
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.
(Inherited from CompositeNode)
prependContent(sourceSection)Inserts a copy of content of the source section at the beginning of this section.
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.
(Inherited from CompositeNode)
removeChild(oldChild)Removes the specified child node.
(Inherited from CompositeNode)
removeSmartTags()Removes all SmartTag descendant nodes of the current node.
(Inherited from CompositeNode)
selectNodes(xpath)Selects a list of nodes matching the XPath expression.
(Inherited from CompositeNode)
selectSingleNode(xpath)Selects the first Node that matches the XPath expression.
(Inherited from CompositeNode)
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 construct an Aspose.words document by hand.

let doc = new aw.Document();

// A blank document contains one section, one body and one paragraph.
// Call the "RemoveAllChildren" method to remove all those nodes,
// and end up with a document node with no children.
doc.removeAllChildren();

// This document now has no composite child nodes that we can add content to.
// If we wish to edit it, we will need to repopulate its node collection.
// First, create a new section, and then append it as a child to the root document node.
let section = new aw.Section(doc);
doc.appendChild(section);

// Set some page setup properties for the section.
section.pageSetup.sectionStart = aw.SectionStart.NewPage;
section.pageSetup.paperSize = aw.PaperSize.Letter;

// A section needs a body, which will contain and display all its contents
// on the page between the section's header and footer.
let body = new aw.Body(doc);
section.appendChild(body);

// Create a paragraph, set some formatting properties, and then append it as a child to the body.
let para = new aw.Paragraph(doc);

para.paragraphFormat.styleName = "Heading 1";
para.paragraphFormat.alignment = aw.ParagraphAlignment.Center;

body.appendChild(para);

// Finally, add some content to do the document. Create a run,
// set its appearance and contents, and then append it as a child to the paragraph.
let run = new aw.Run(doc);
run.text = "Hello World!";
run.font.color = "#FF0000";
para.appendChild(run);

expect(doc.getText().trim()).toEqual("Hello World!");

doc.save(base.artifactsDir + "Section.CreateManually.docx");

See Also