Generating PDF files with JavaScript – Dev

The best answers to the question “Generating PDF files with JavaScript” in the category Dev.


Iā€™m trying to convert XML data into PDF files from a web page and I was hoping I could do this entirely within JavaScript. I need to be able to draw text, images and simple shapes. I would love to be able to do this entirely in the browser.


Another javascript library worth mentioning is pdfmake.

  • pdfmake playground
  • pdfmake on github

The browser support does not appear to be as strong as jsPDF, nor does there seem to be an option for shapes, but the options for formatting text are more advanced then the options currently available in jsPDF.


I’ve just written a library called jsPDF which generates PDFs using Javascript alone. It’s still very young, and I’ll be adding features and bug fixes soon. Also got a few ideas for workarounds in browsers that do not support Data URIs. It’s licensed under a liberal MIT license.

I came across this question before I started writing it and thought I’d come back and let you know šŸ™‚

Generate PDFs in Javascript

Example create a “Hello World” PDF file.

// Default export is a4 paper, portrait, using milimeters for units
var doc = new jsPDF()

doc.text('Hello world!', 10, 10)'a4.pdf')
<script src=""></script>


Another interesting project is texlive.js.

It allows you to compile (La)TeX to PDF in the browser.


I maintain PDFKit, which also powers pdfmake (already mentioned here). It works in both Node and the browser, and supports a bunch of stuff that other libraries do not:

  • Embedding subsetted fonts, with support for unicode.
  • Lots of advanced text layout stuff (columns, page breaking, full unicode line breaking, basic rich text, etc.).
  • Working on even more font stuff for advanced typography (OpenType/AAT ligatures, contextual substitution, etc.). Coming soon: see the fontkit branch if you’re interested.
  • More graphics stuff: gradients, etc.
  • Built with modern tools like browserify and streams. Usable both in the browser and node.

Check out for a full tutorial to see for yourself what PDFKit can do. And for an example of what kinds of documents can be produced, check out the docs as a PDF generated from some Markdown files using PDFKit itself:

You can also try it out interactively in the browser here: