How to display a PDF as an image in React app using URL? - GeeksforGeeks (2024)

Last Updated : 26 Jul, 2024

Summarize

Comments

Improve

If we use the fetch method then it will open a new window for displaying the PDF file and let users download the PDF. But if you don’t want that then there is a way to do so. You can use the package called react-pdf, by using this package you can render the PDF in your React app by using the PDF URL.

Prerequisites:

  • Your project needs to use React 16.3 or later.
  • Basic knowledge of packages

React-pdf: It lets you display PDF in your React app as easily as if they were images. It helps to create custom components that you can use to create and structure your PDF documents.

Step 1: Create React App

npx create-react-app appname

cd appname

npm start

Step 2: Install react-pdf package.

npm install react-pdf

Step 3: First make a separate component PDF (name of the component, can be anything) and render the PDF component in App.js.

App.js:

JavaScript
import React from 'react';import Pdf from './Pdf'const App = ()=> { return ( <div className="App"> //Rendering a pdf component <Pdf /> </div> );}export default App;

After creating a pdf component your project directory will look like this.

How to display a PDF as an image in React app using URL? - GeeksforGeeks (1)

Step 4: In this section, we load the PDF and render it on your app.

Document: Loads a document passed using file prop.

File Prop: It tells what PDF should be displayed, In the above code, we pass URL to it.

URL: The URL consists of two parts here.

  • The 1st part is due to preventing cors error, you may refer docs to read more about the core.
1st part: https://cors-anywhere.herokuapp.com/ 
  • The 2nd part is our actual URL of PDF.
2nd part: http://www.pdf995.com/samples/pdf.pdf

One more thing we need to do is ENABLE PDF.JS WORKER, you could use pdf.worker.js from an external CDN.

onDocumentLoadSuccess: When the document gets successfully loaded we set the state of page number to tells on which page number of pdf the user is.

Pdf.js: Now open the PDF component.

JavaScript
import React, { useState } from 'react';import { Document, Page,pdfjs } from 'react-pdf';import './pdf.css'//PDFjs worker from an external cdnconst url = "https://cors-anywhere.herokuapp.com/http://www.pdf995.com/samples/pdf.pdf"export default function Test() {  pdfjs.GlobalWorkerOptions.workerSrc =  `//cdnjs.cloudflare.com/ajax/libs/pdf.js/${pdfjs.version}/pdf.worker.js`; const [numPages, setNumPages] = useState(null); const [pageNumber, setPageNumber] = useState(1); function onDocumentLoadSuccess({ numPages }) { setNumPages(numPages); setPageNumber(1); } return ( <> <div className="main"> <Document file={url} onLoadSuccess={onDocumentLoadSuccess} > <Page pageNumber={pageNumber} /> </Document> </div> </> );}

Step 5: Now the last thing add NEXT and PREVIOUS buttons to PDF file.

Pdf.js: Here we added two buttons NEXT AND PREVIOUS and their functions named previousPage() and nextPage() which change the state of the current page.

JavaScript
import React, { useState } from 'react';import { Document, Page,pdfjs } from 'react-pdf';const url = "https://cors-anywhere.herokuapp.com/http://www.pdf995.com/samples/pdf.pdf"export default function Test() {  pdfjs.GlobalWorkerOptions.workerSrc =  `//cdnjs.cloudflare.com/ajax/libs/pdf.js/${pdfjs.version}/pdf.worker.js`; const [numPages, setNumPages] = useState(null); const [pageNumber, setPageNumber] = useState(1); /*To Prevent right click on screen*/ document.addEventListener("contextmenu", (event) => { event.preventDefault(); });  /*When document gets loaded successfully*/ function onDocumentLoadSuccess({ numPages }) { setNumPages(numPages); setPageNumber(1); } function changePage(offset) { setPageNumber(prevPageNumber => prevPageNumber + offset); } function previousPage() { changePage(-1); } function nextPage() { changePage(1); } return ( <> <div className="main"> <Document file={url} onLoadSuccess={onDocumentLoadSuccess} > <Page pageNumber={pageNumber} /> </Document> <div> <div className="pagec"> Page {pageNumber || (numPages ? 1 : '--')} of {numPages || '--'} </div> <div className="buttonc"> <button type="button" disabled={pageNumber <= 1} onClick={previousPage} className="Pre"  > Previous </button> <button type="button" disabled={pageNumber >= numPages} onClick={nextPage}  > Next </button> </div> </div> </div> </> );}

Output:



Please Login to comment...

How to display a PDF as an image in React app using URL? - GeeksforGeeks (2024)
Top Articles
Download Coin Master for Android - Free
Top 25 Highest Paying Jobs in the World-2024
Moto X3M Game - Play Unblocked Game Online for Free!
Little League Coach Daily Themed Crossword
888-490-1703
Globle Answer March 1 2023
Yahoo Sports Pga Leaderboard
Reading Craigslist Pa
Skeleton Soldier Failed To Defend The Dungeon Wiki
GIF by Barstool Sports - Find & Share on GIPHY
[H] Wasteland 3, Cuphead, Resident Evil 7, Cloudpunk, Firewatch, Heavy Rain [W] Offers, Skins
Unblocked Games6969: A World Of Unrestricted Gaming Fun - Unblocked Hub
Harnett County Detention Center NC Recent Arrests and Bookings
Jack In The Box Menu 2022
Temu Balloon
3D Billiards & 3D MiniGolf Bundle
Generation Zero - Weapon Locations Guide - Gamer Tag Zero
Eemax Eem24027 Reset Button
Devotion Showtimes Near Amc Hoffman Center 22
Fox News 10 Mobile Al
Toledo Schools Closed
Pollen Count Los Altos
The Africa Forum Berlin: Reframing Conservation for a Sustainable Future
415-261-2242
Jessica Oldwyn Carroll Update
Qdoba Gull Road
Lucki White House Lyrics
Njdep Org Chart
Wal-Mart 140 Supercenter Products
Rhiel Funeral Durand
Room Deals for Meritas Picaddle Resort - Lonavala, Mawal starting at
Shiftselect Carolinas
Brenda Song Wikifeet
Liberty Taxi Plainfield Nj
Carly Hart Playboy
Karen Khachanov Flashscore
Lesson 6 Becoming Familiar With Blueprint Systems Integration
Westy20 Proud Father
Costco Gas Prices Macomb Mi
Montgomery Advertiser Obituaries
9Xmovie Worldfree4U
Uintah County Animal Shelter Adoption
Effingham Bookings Florence Sc
Coors Field Seats In The Shade
Myhr Pepsico Login
Lahabraschools
Syracuse Football 247
Mydocbill.com/Mr
Harper and Finley Lockwood Biography, Age, Height, Husband, Net Worth, Family
Litquidity Compensation Survey
2024 Indian Calendar for Indian Festivals and Indian Holidays
Latest Posts
Article information

Author: Neely Ledner

Last Updated:

Views: 5937

Rating: 4.1 / 5 (42 voted)

Reviews: 89% of readers found this page helpful

Author information

Name: Neely Ledner

Birthday: 1998-06-09

Address: 443 Barrows Terrace, New Jodyberg, CO 57462-5329

Phone: +2433516856029

Job: Central Legal Facilitator

Hobby: Backpacking, Jogging, Magic, Driving, Macrame, Embroidery, Foraging

Introduction: My name is Neely Ledner, I am a bright, determined, beautiful, adventurous, adventurous, spotless, calm person who loves writing and wants to share my knowledge and understanding with you.