Skip to main content
Module

x/docx/demo/14-page-numbers.ts

Easily generate .docx files with JS/TS with a nice declarative API. Works for Node and on the Browser.
Go to Latest
File
// Page numbers// Import from 'docx' rather than '../build' if you install from npmimport * as fs from "fs";import { AlignmentType, Document, Footer, Header, Packer, PageBreak, PageNumber, Paragraph, TextRun } from "../build";
const doc = new Document({ sections: [ { properties: { titlePage: true, }, headers: { default: new Header({ children: [ new Paragraph({ alignment: AlignmentType.RIGHT, children: [ new TextRun("My Title "), new TextRun({ children: ["Page ", PageNumber.CURRENT], }), ], }), ], }), first: new Header({ children: [ new Paragraph({ alignment: AlignmentType.RIGHT, children: [ new TextRun("First Page Header "), new TextRun({ children: ["Page ", PageNumber.CURRENT], }), ], }), ], }), }, footers: { default: new Footer({ children: [ new Paragraph({ alignment: AlignmentType.RIGHT, children: [ new TextRun("My Title "), new TextRun({ children: ["Footer - Page ", PageNumber.CURRENT], }), ], }), ], }), first: new Footer({ children: [ new Paragraph({ alignment: AlignmentType.RIGHT, children: [ new TextRun("First Page Footer "), new TextRun({ children: ["Page ", PageNumber.CURRENT], }), ], }), ], }), }, children: [ new Paragraph({ children: [new TextRun("First Page"), new PageBreak()], }), new Paragraph("Second Page"), ], }, ],});
Packer.toBuffer(doc).then((buffer) => { fs.writeFileSync("My Document.docx", buffer);});