Skip to footer content
NODE HELP

JsdomNPM (How It Works For Developers)

When JSDOM and IronPDF are combined in Node.js, programmers have access to an extensive toolkit for creating and modifying PDF documents. A pure JavaScript implementation of the W3C DOM called JSDOM makes it possible to manipulate HTML and XML documents server-side in a manner akin to what is possible in a browser. Conversely, IronPDF uses simple Node.js APIs to make it easier to create high-quality PDFs from HTML content.

Combining JSDOM and IronPDF allows developers to easily transform web pages into PDFs within their Node.js apps, change pre-existing PDFs, and create PDF documents from HTML templates on the fly. This combination is a great option for projects requiring strong PDF creation capabilities because it not only ensures compliance with contemporary web technologies but also speeds up document generation operations.

What is JSDOM NPM?

JSDOM NPM (Node Package Manager) is a JavaScript library that lets you use Node.js to parse and work with HTML documents. It offers a browser-like environment inside Node.js and supports the W3C DOM (Document Object Model). As a result, you may manipulate the characteristics and content of HTML and XML documents programmatically. You can even simulate actions like clicks and form submissions.

JSDOM NPM (How It Works For Developers): Figure 1

JSDOM is very helpful for activities like creating HTML-based reports, testing and verifying online sites, and web scraping. When working with HTML pages in a server-side setting, where standard browser functions are not available, it helps developers. The JSDOM NPM package bridges the gap between client-side browser functionality and server-side JavaScript by handling HTML manipulation and interaction in Node.js applications.

With its implementation of many robust web capabilities, JSDOM in Node.js is a useful tool for developers working in server-side environments with HTML and XML documents. JSDOM's salient characteristics are as follows:

W3C DOM Implementation

A comprehensive JavaScript implementation of many of the W3C DOM and HTML specifications is offered by JSDOM. This enables you to use well-known DOM APIs to programmatically manipulate HTML and XML documents.

Browser-like Environment

Because JSDOM imitates a browser environment within Node.js, you can manipulate HTML pages just like you would if JavaScript were being performed in a browser. This covers working with the document object model, managing events, executing scripts, and accessing and changing items.

Support for Standards

Modern web standards, including HTML5, CSS3, and the newest JavaScript features are supported. This guarantees compatibility with the majority of web content and makes it possible to manipulate and parse complex pages accurately.

Parsing and Serialization

HTML strings can be parsed by JSDOM into DOM structures, and DOM nodes can be serialized back into HTML strings. This is to enable executing scripts inside the page and allow us to edit and produce updated HTML output from web pages.

Customizable Configuration

JSDOM can be configured to mimic many browser-related features, including the processing of external resources (like loading external scripts and executing external scripts or stylesheets), switching between different JavaScript engines (like V8 or SpiderMonkey), and more.

Integration with Testing Frameworks

JSDOM is a popular tool for writing unit tests and integration tests including DOM manipulation in testing frameworks like Jest and Mocha. It makes it possible to test web apps headless without needing a whole browser environment.

Accessibility and Compatibility

It is appropriate for applications that need to comply with accessibility standards since it has accessibility features like compatibility with screen readers and support for ARIA properties.

Node.js Ecosystem Integration

JSDOM works well with other libraries and the larger Node.js ecosystem. It can be used, for instance, in conjunction with packages like Puppeteer for more complex web scraping and automation activities or with Cheerio for effective HTML parsing.

Create and Configure JSDOM Node.js

The steps below can be used to construct and configure JSDOM in a Node.js application:

Install JSDOM

First, make sure that npm and Node.js are installed on your computer. npm can be used to install JSDOM:

npm install jsdom
npm install jsdom
SHELL

Basic JSDOM Usage

This is a simple example of setting up a JSDOM environment and working with an HTML document:

const { JSDOM } = require('jsdom');

// Example HTML content
const htmlContent = `
<!DOCTYPE html>
<html>
<head>
  <title>JSDOM Example</title>
</head>
<body>
  <div id="content">
    <p>Hello, JSDOM!</p>
  </div>
</body>
</html>
`;

// Create a JSDOM instance
const dom = new JSDOM(htmlContent);

// Access and manipulate the DOM
const document = dom.window.document;
const contentDiv = document.getElementById('content');
contentDiv.innerHTML = '<p>Hello, modified JSDOM!</p>';

// Serialize the modified DOM back to HTML
const modifiedHtml = dom.serialize();
console.log(modifiedHtml);
const { JSDOM } = require('jsdom');

// Example HTML content
const htmlContent = `
<!DOCTYPE html>
<html>
<head>
  <title>JSDOM Example</title>
</head>
<body>
  <div id="content">
    <p>Hello, JSDOM!</p>
  </div>
</body>
</html>
`;

// Create a JSDOM instance
const dom = new JSDOM(htmlContent);

// Access and manipulate the DOM
const document = dom.window.document;
const contentDiv = document.getElementById('content');
contentDiv.innerHTML = '<p>Hello, modified JSDOM!</p>';

// Serialize the modified DOM back to HTML
const modifiedHtml = dom.serialize();
console.log(modifiedHtml);
JAVASCRIPT

JSDOM NPM (How It Works For Developers): Figure 2

Configuration Options

The JSDOM constructor accepts options that you can supply to customize different parts of its functionality. These are a few typical setup choices:

It regulates how scripts and stylesheets from external resources should be loaded by the JSDOM object API. Decide if the scripts in the parsed HTML should be executed by JSDOM. Allows scripts running inside of JSDOM to have their console output captured. Mimics the visual environment of a browser, which could have an impact on several CSS and layout calculations.

This is an illustration of setting up JSDOM code using options.

const { JSDOM } = require('jsdom');

const htmlContent = '<!DOCTYPE html><html><body><p>Hello, JSDOM!</p></body></html>';

const options = {
  resources: 'usable', // Load external resources (e.g., scripts, stylesheets)
  runScripts: 'dangerously', // Allow scripts to run
};

const dom = new JSDOM(htmlContent, options);

// Access the document and window objects
const document = dom.window.document;
const window = dom.window;

// Manipulate the DOM or interact with the window object here
console.log(document.documentElement.outerHTML); // Output the modified HTML
const { JSDOM } = require('jsdom');

const htmlContent = '<!DOCTYPE html><html><body><p>Hello, JSDOM!</p></body></html>';

const options = {
  resources: 'usable', // Load external resources (e.g., scripts, stylesheets)
  runScripts: 'dangerously', // Allow scripts to run
};

const dom = new JSDOM(htmlContent, options);

// Access the document and window objects
const document = dom.window.document;
const window = dom.window;

// Manipulate the DOM or interact with the window object here
console.log(document.documentElement.outerHTML); // Output the modified HTML
JAVASCRIPT

Advanced Usage

In more complicated situations, such as connecting test code with testing frameworks or emulating user interactions, JSDOM can also be applied. Here's an illustration of how to use JSDOM and Jest for testing:

const { JSDOM } = require('jsdom');

test('modifying DOM with JSDOM', () => {
  const dom = new JSDOM('<!DOCTYPE html><html><body><p>Hello, JSDOM!</p></body></html>');
  const document = dom.window.document;
  const contentParagraph = document.querySelector('p');

  // Assert initial content
  expect(contentParagraph.textContent).toBe('Hello, JSDOM!');

  // Modify content
  contentParagraph.textContent = 'Hello, modified JSDOM!';

  // Assert modified content
  expect(contentParagraph.textContent).toBe('Hello, modified JSDOM!');
});
const { JSDOM } = require('jsdom');

test('modifying DOM with JSDOM', () => {
  const dom = new JSDOM('<!DOCTYPE html><html><body><p>Hello, JSDOM!</p></body></html>');
  const document = dom.window.document;
  const contentParagraph = document.querySelector('p');

  // Assert initial content
  expect(contentParagraph.textContent).toBe('Hello, JSDOM!');

  // Modify content
  contentParagraph.textContent = 'Hello, modified JSDOM!';

  // Assert modified content
  expect(contentParagraph.textContent).toBe('Hello, modified JSDOM!');
});
JAVASCRIPT

Getting Started

Getting IronPDF and JSDOM working in Node.js entails combining these libraries in order to convert HTML information into PDF documents. JSDOM lets you work with HTML documents using programming, while IronPDF makes it easier to convert HTML to PDF. Here's a how-to manual to get you going.

What is IronPDF for Node.js?

IronPDF for Node.js produces PDF documents of superior quality from HTML text. While preserving the integrity of the original web content, it makes the process of converting HTML, CSS, and JavaScript into fully formatted PDFs easier. Web applications that need to generate dynamic, printable documents like reports, invoices, and certifications may find this tool especially helpful.

Among the many capabilities that IronPDF provides are adjustable page settings, headers, footers, and the ability to embed images and fonts. In order to guarantee that the generated PDFs adhere to the intended design, it allows intricate layouts and styles. Furthermore, IronPDF manages the execution of JavaScript inside HTML, enabling precise rendering of dynamic and interactive material.

JSDOM NPM (How It Works For Developers): Figure 3

Features of IronPDF

PDF Generation from HTML

Convert JavaScript, HTML, and CSS to PDF. Supports media queries and responsive design, two contemporary web standards. Useful for dynamically decorating PDF documents, reports, and bills using HTML and CSS.

PDF Editing

Pre-existing PDFs can have text, images, and other content added to them, or alternatively, you can take text and pictures out of these PDF files. Combine numerous PDFs into one file. Divide PDF files into multiple separate papers. Include watermarks, annotations, headers, and footers.

Performance and Reliability

High performance and dependability are desired design qualities in industrial settings. IronPDF manages big document sets with ease.

Install IronPDF

Install the IronPDF package to get the tools you need to work with PDFs in node projects.

npm install @ironsoftware/ironpdf
npm install @ironsoftware/ironpdf
SHELL

Convert HTML to PDF using JSDOM and IronPDF

Get the HTML material ready to be converted to a PDF. As an illustration:

<!-- example.html -->
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Example Document</title>
  <style>
    body {
      font-family: Arial, sans-serif;
    }
    .content {
      margin: 20px;
    }
  </style>
</head>
<body>
  <div class="content">
    <h1>Hello, JSDOM with IronPDF!</h1>
    <p>This is a sample HTML document converted to PDF using JSDOM and IronPDF.</p>
  </div>
</body>
</html>
<!-- example.html -->
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Example Document</title>
  <style>
    body {
      font-family: Arial, sans-serif;
    }
    .content {
      margin: 20px;
    }
  </style>
</head>
<body>
  <div class="content">
    <h1>Hello, JSDOM with IronPDF!</h1>
    <p>This is a sample HTML document converted to PDF using JSDOM and IronPDF.</p>
  </div>
</body>
</html>
HTML

Make a Node.js script called convertToPdf.js that parses the HTML content using JSDOM and creates a PDF using IronPDF.

const { JSDOM } = require('jsdom');
const IronPdf = require("@ironsoftware/ironpdf");
const fs = require('fs');

// Configure IronPDF with the license key (if applicable)
var config = IronPdf.IronPdfGlobalConfig;
config.setConfig({ licenseKey: '' });

// Load the HTML content from the file
const htmlContent = fs.readFileSync('example.html', 'utf8');

// Create a JSDOM instance and parse the HTML
const dom = new JSDOM(htmlContent);
const jdocument = dom.window.document;

// Convert the HTML to PDF
IronPdf.PdfDocument.fromHtml(jdocument.documentElement.outerHTML).then((pdfres) => {
  const filePath = `${Date.now()}.pdf`;
  pdfres.saveAs(filePath).then(() => {
    console.log('PDF saved successfully!');
  }).catch((e) => {
    console.log(e);
  });
});
const { JSDOM } = require('jsdom');
const IronPdf = require("@ironsoftware/ironpdf");
const fs = require('fs');

// Configure IronPDF with the license key (if applicable)
var config = IronPdf.IronPdfGlobalConfig;
config.setConfig({ licenseKey: '' });

// Load the HTML content from the file
const htmlContent = fs.readFileSync('example.html', 'utf8');

// Create a JSDOM instance and parse the HTML
const dom = new JSDOM(htmlContent);
const jdocument = dom.window.document;

// Convert the HTML to PDF
IronPdf.PdfDocument.fromHtml(jdocument.documentElement.outerHTML).then((pdfres) => {
  const filePath = `${Date.now()}.pdf`;
  pdfres.saveAs(filePath).then(() => {
    console.log('PDF saved successfully!');
  }).catch((e) => {
    console.log(e);
  });
});
JAVASCRIPT

JSDOM NPM (How It Works For Developers): Figure 4

Load HTML content from a database, file, or dynamically created content. To create a PDF document from the parsed HTML content, use IronPDF. The HTML string is accepted by IronPDF's RenderHtmlAsPdf function, which then delivers a Promise with the PDF data. Using the file system module (fs) of Node.js, IronPDF creates the PDF document as a buffer (pdfBuffer), which may be saved to a file. Error handling guarantees resilience in the event of problems, like corrupted HTML or network difficulties, during the creation of PDFs.

JSDOM NPM (How It Works For Developers): Figure 5

Conclusion

For programmatically creating high-quality PDF documents from HTML information, JSDOM offers a reliable option. With JSDOM, developers may interact with DOM elements and dynamically edit information by making it easier to parse and manipulate HTML pages in a simulated browser environment. This feature is essential for jobs like data extraction, dynamic report generation, and web scraping.

With its robust capabilities for turning HTML texts into PDFs that give you exact control over layout, pagination, headers, footers, and other PDF-specific features, IronPDF is a great addition to JSDOM. It makes it easier to convert complicated HTML structures from Node.js apps directly into printable, prepared PDF files.

Combining JSDOM and IronPDF allows developers to create PDF documents from HTML templates or dynamically generated information automatically. This makes the documents useful for a variety of use cases, such as producing reports, certificates, invoices, and more. This integration efficiently meets the unique requirements of document-centric applications inside the Node.js ecosystem by utilizing the strengths of both libraries to improve productivity and preserve document fidelity.

IronPDF and Iron Software enable you to extend the capabilities of your .NET development toolkit with OCR, barcode scanning, PDF creation, Excel integration, and other features. IronPDF combines Iron Software's highly configurable systems and suite with its core support to provide developers with additional online apps and features, as well as more efficient development, all for only $749 for the base edition.

When license options are clear and tailored to the project, developers may select the optimal model with greater ease. These features assist developers in solving a wide range of issues in a straightforward, effective, and well-integrated manner.

Darrius Serrant
Full Stack Software Engineer (WebOps)

Darrius Serrant holds a Bachelor’s degree in Computer Science from the University of Miami and works as a Full Stack WebOps Marketing Engineer at Iron Software. Drawn to coding from a young age, he saw computing as both mysterious and accessible, making it the perfect medium for creativity ...Read More

Ready to Get Started?
Version: 2025.10 just released