Pas exactement comme ça, mais il existe des solutions de contournement. Il y a une section dans la documentation de React sur le rendu conditionnel que vous devriez jeter un coup d'œil. Voici un exemple de ce que vous pourriez faire en utilisant if-else en ligne.
render() {
const isLoggedIn = this.state.isLoggedIn;
return (
<div>
{isLoggedIn ? (
<LogoutButton onClick={this.handleLogoutClick} />
) : (
<LoginButton onClick={this.handleLoginClick} />
)}
</div>
);
}
Vous pouvez également le gérer dans la fonction de rendu, mais avant de renvoyer le jsx.
if (isLoggedIn) {
button = <LogoutButton onClick={this.handleLogoutClick} />;
} else {
button = <LoginButton onClick={this.handleLoginClick} />;
}
return (
<div>
<Greeting isLoggedIn={isLoggedIn} />
{button}
</div>
);
Il convient également de mentionner ce que ZekeDroid a évoqué dans les commentaires. Si vous recherchez simplement une condition et que vous ne souhaitez pas rendre un morceau de code particulier qui n'est pas conforme, vous pouvez utiliser le && operator
.
return (
<div>
<h1>Hello!</h1>
{unreadMessages.length > 0 &&
<h2>
You have {unreadMessages.length} unread messages.
</h2>
}
</div>
);