render-vendor is the fastest way to render HTML documents to PDFs

(or PNGs, JPEGs, BMPs…)

The Renderer loads HTML templates into Pages, which are later rendered into the desired format. With render-vendor, you can:

  • Generate PDFs in 10s of milliseconds (10-100x faster than several popular solutions);
  • Handle jobs asynchronously;
  • Swap internal components, e.g. Headless Chrome vs. PhantomJS; and
  • Integrate easily into modern JS build pipelines (e.g. React, Glimmer, Vue). For Ember + Electron projects, consider using ember-render-vendor


Global (CLI) interface:
yarn global add render-vendor
// or npm install -g render-vendor


👶 New to Node.js?: See more

render-vendor cli demo

Library (Node.js) interface


Install via yarn or npm:

yarn add render-vendor
// or npm install --save render-vendor


Open the Node.js REPL (i.e. type node in your working directory from above), then run the following:

const { Renderer } = require('render-vendor');

Renderer.load('').then((page) => {
  return page.render('./out.pdf');
}).catch((err) => {
}).then(() => {
}).then(() => {

The process should exit automatically, and your directory should have a shiny new out.pdf!


Are you building an Ember.js + Electron app? Check out ember-render-vendor, a companion lib that: uses the Broccoli build pipeline to:

  • Synchronize data between your main application and rendered Page objects; and
  • Make writing parallel renderering queues as simple as writing components.


render-vendor is maintained by Isle of Code in Toronto. Initial release was sponsored by Common Sort.

Thanks also to @marcbachmann & contributors to node-html-pdf, from which PhantomRenderer’s internal render() implementation was lovingly aped.

👶 New to Node.js:

Assuming you’ve installed Node.js, try the following:

  • cd into a working directory (or mkdir a new one);
  • Run npm init and follow the prompts to create your first package.json; then
  • Run the npm install command above: npm install render-vendor.