Drag-and-drop uploads in React (video tutorial)
Last updated: Aug-31-2025
On this page:
Overview
Learn how to implement drag-and-drop uploads to Cloudinary in your React app using the react-dropzone library.
Video tutorial
This video is brought to you by Cloudinary's video player - embed your own!
Use the controls to set the playback speed, navigate to chapters of interest and select subtitles in your preferred language.
View the code
You can find the code from this tutorial in GitHub.Tutorial contents
This tutorial presents the following topics. Click a timestamp to jump to that part of the video.
Introduction to file upload in React
| The traditional way to select files on websites is using a file picker input element. However, to achieve drag-and-drop functionality, you can use the browser's drag-and-drop API or a library like react-dropzone, which simplifies this process. This tutorial demonstrates how to set upreact-dropzone, import its component, and use theuseDropzonehook with anonDropcallback function to handle selected files and preview the selected image. | |
Setting up drag-and-drop with react-dropzone
| Ensure your React application is set up, then install react-dropzonewithnpm install react-dropzone. Import theuseDropzonehook by addingimport { useDropzone } from "react-dropzone". Set up theonDropcallback to log selected files, and destructure properties and methods likegetRootPropsandacceptedFilesto manage drag-and-drop actions. | |
Spreading react-dropzone props in a <div>
| Spread the props from getRootProps()andgetInputProps()onto the<div>to make it handle drag-and-drop events. | |
Accessing selected files
| Use acceptedFilesto access the array of selected files. Try logging the first selected file withconsole.logto see it in action. | |
Setting state for data URL
| In the onDropfunction, loop through the selected files (in this example, just one file). Use theFileReaderAPI to read the file and listen for theonloadevent. Once the file has been read, set the file'sdataURLas a state variable to display an image preview. | |
Implementing visual feedback for drag-and-drop
| Implement visual feedback by checking isDragActive, which becomestruewhen a file is being dragged over the drop zone. Use this state to show a message or overlay, and ifdataURLis notnull, display a preview of the selected image along with options to upload or cancel. The buttons displayed on the preview provide a way to either cancel the action or upload the selected image, triggering the uploadImage function. | |
Setting Up Cloudinary for file uploads
| To upload files to Cloudinary, you can use various methods. This tutorial shows how to use the upload endpoint to perform an unsigned upload for testing purposes, though signed uploads are recommended for production. Get your API key and save your credentials in a .envfile. Then, create an unsigned upload preset. | |
Creating the uploadImage function
| Create an uploadImagefunction that uploads the file to Cloudinary using the provided API endpoint and upload preset. After uploading, store the returned URL and update the state with the response. | |
Displaying the uploaded file
| After a successful upload, update the state with the public URL from the Cloudinary response and display the uploaded image in your application. | |
Testing drag-and-drop functionality
| Test your drag-and-drop functionality with Cloudinary integration. Drag a file into the drop zone, preview it, and then upload it to Cloudinary. Once uploaded, the file’s public URL is displayed, confirming successful integration. | |
Keep learning
Related topics
- Read our Upload widget guide and reference to find out about another useful way to upload in React.
- Check out some React sample projects that can be useful to you when creating your own app.
- Take a look at our React SDK to learn how to transform your images and videos.
- Watch more Dev Hints videos on the Cloudinary YouTube channel.
If you like this, you might also like...
Check out the Cloudinary Academy for free self-paced Cloudinary courses on a variety of developer or DAM topics, or register for formal instructor-led courses, either virtual or on-site.
✖️  
