React Conditional Rendering
In React, you can conditionally render components.
There are several ways to achieve conditional rendering:
-
If statement: Use a regular
if
statement to conditionally render components or elements based on a condition. -
Ternary operator: Use a ternary operator (
condition ? trueBlock : falseBlock
) to render different components or elements based on a condition. -
Logical && operator (Short Circuit Evaluation): Use the logical
&&
operator (condition && renderBlock
) to conditionally render a block of JSX based on a condition. The block is only rendered if the condition is true. -
Switch statement: Use a
switch
statement to handle multiple conditions and render different components or elements based on each condition. -
Inline condition: Use inline conditions within JSX (
{condition ? renderBlock : null}
) to render a block of JSX based on a condition. -
Render function: Use a render function or a component that returns JSX. Inside the function, you can implement any JavaScript logic to conditionally render components or elements.
The conditional (ternary) operator is the only JavaScript operator that takes three operands. This operator is frequently used as a shortcut for the if statement.
Syntax: {cond ? <A /> : <B />}
means “if cond
, render <A />
, otherwise <B />
”.
Sample
{itemCollapsed ? (
<CommandItem title='Expand' />
) : (
<CommandItem title='Collapse' />
)}
In React it often comes up when you want to render some JSX when the condition is true, or render nothing otherwise.
Syntax: {cond && <A />}
means “if cond
, render <A />
, otherwise nothing”.
Sample
{article.content.length > 0 && (
<ArticleContent content={article.content} slug={article.slug} />
)
Comments