This article will show how to create PDF in JS/React from JSON data.
As developers, we must integrate PDF generation within the application. So, in this article, we will discuss creating PDFs using jspdf.
So, Let’s get started.
We will use a React environment specifically for this article. I assume you’re familiar with JavaScript/React and have already set up the React environment
Before diving in, we need some sample data to generate the PDF. We’ll create a method to generate this data.
const generateUsers = (count) => { const users = []; for (let i = 1; i <= count; i++) { const user = { id: i, firstName: `firstName_${i}`, lastName: `lastName_${i}`, email: `email_${i}@example.com`, address: [ `Street ${i + 1}, Address Line 1`, `District ${(i % 7) + 1}, City_${i}`, ], }; users.push(user); } return users; };
Now, we need to install some npm packages jspdf and jspdf-autotable.
jsPDF is responsible for creating PDFs, while jsPDF-AutoTable is used to display data in a table format within the PDF.
You can use the following command to install both packages.
npm i jspdf-autotable jspdf
Now, we are going to develop a method to handle PDF creation. I’ll create a generic generatePDF method, so you can use it anywhere you need.
1. Function Definition
The function generatePDF takes data as an argument, which is expected to be an array of objects (the JSON data to include in the PDF).
export const generatePDF = (data) => {
2. PDF Document Setup
A new jsPDF instance is created with the following options:
const doc = new jsPDF("l", "pt", "a3"); // if you want to use custom dimensions // width,height const doc = new jsPDF("l", "pt", [3000,1000]);
3. Adding Title to the PDF
doc.setFontSize(16); doc.text("JSON Data PDF", doc.internal.pageSize.getWidth() / 2, 30, { align: "center", });
4. Extracting Table Headers
const tableColumnHeaders = Object.keys(data[0]);
5. Formatting Table Rows
Iterates over each object in data, creating a new array (tableRows) where:
const tableRows = data.map((row) => Object.keys(row).map((key) => { const value = row[key]; if (Array.isArray(value)) { return value.join(", "); } return value; }) );
6. Adding the Table to the PDF
Configures the table with the following options:
const generateUsers = (count) => { const users = []; for (let i = 1; i <= count; i++) { const user = { id: i, firstName: `firstName_${i}`, lastName: `lastName_${i}`, email: `email_${i}@example.com`, address: [ `Street ${i + 1}, Address Line 1`, `District ${(i % 7) + 1}, City_${i}`, ], }; users.push(user); } return users; };
7. Saving the PDF
Saves the PDF file with the filename "JS-pdf.pdf".
npm i jspdf-autotable jspdf
Here is the full version of this code.
export const generatePDF = (data) => {
const doc = new jsPDF("l", "pt", "a3"); // if you want to use custom dimensions // width,height const doc = new jsPDF("l", "pt", [3000,1000]);
This is done for now. Hopefully, you enjoyed it. Have a nice day !!!
The above is the detailed content of How to Create PDFs in React from JSON Data with jsPDF. For more information, please follow other related articles on the PHP Chinese website!