How to render HTML in React
Find out how to render an HTML string in the DOM without escaping, using React
I had this problem - I needed to add an HTML string in a React application, coming from a WYSIWYG editor, but simply adding {myString}
to the JSX was escaping the HTML.. so the HTML tags were displayed to the user!
How did I solve it? I saw 2 solutions, basically. The first native, the second required a library.
First solution: use dangerouslySetInnerHTML
You can use the dangerouslySetInnerHTML
attribute on an HTML element to add an HTML string inside its content:
<div
dangerouslySetInnerHTML={{
__html: props.house.description
}}></div>
Remember that it’s called dangerously for a reason. HTML is not escaped at all in this case, and it might cause XSS issues.
But there are good use cases for this.
Second solution: use a 3rd party library
There are many libraries that implement the functionality that dangerouslySetInnerHTML
provides, in a simpler way.
One of them is the react-html-parser
library.
See the library on GitHub: https://github.com/wrakky/react-html-parser
Warning: at the time of writing, it’s not been updated in the last 2 years, so things might break in the future. It worked for me.
Which one to use?
You can look for other similar libraries, but in the end I chose to use the dangerouslySetInnerHTML
way.
This dangerously-looking name was a built-in reminder to pay attention at correctly whitelisting the HTML tags I allowed the user to enter to that HTML string.
I wrote 17 books to help you become a better developer, download them all at $0 cost by joining my newsletter
- C Handbook
- Command Line Handbook
- CSS Handbook
- Express Handbook
- Git Cheat Sheet
- Go Handbook
- HTML Handbook
- JS Handbook
- Laravel Handbook
- Next.js Handbook
- Node.js Handbook
- PHP Handbook
- Python Handbook
- React Handbook
- SQL Handbook
- Svelte Handbook
- Swift Handbook
JOIN MY CODING BOOTCAMP, an amazing cohort course that will be a huge step up in your coding career - covering React, Next.js - next edition February 2025