Conditional rendering in React
How to dynamically output something vs something else in React
In a React component JSX you can dynamically decide to output some component or another, or just some portion of JSX, based on conditionals.
The most common way is probably the ternary operator:
const Pet = (props) => {
return (
{props.isDog ? <Dog /> : <Cat />}
)
}
Another way, which works great when you conceptually have an if
but not an else
is to use the &&
operator, which works this way: if the expression before it evaluates to true, it prints the expression after it:
const Pet = (props) => {
return (
{props.isDog && <Dog />}
{props.isCat && <Cat />}
)
}
→ Get my React Beginner's Handbook
→ I wrote 17 books to help you become a better developer:
- 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
Also, 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