ไม่ใช่อย่างนั้น แต่มีวิธีแก้ปัญหา มีส่วนหนึ่งในเอกสารของ Reactเกี่ยวกับการแสดงผลแบบมีเงื่อนไขที่คุณควรดู นี่คือตัวอย่างของสิ่งที่คุณสามารถทำได้โดยใช้ inline if-else
render() {
const isLoggedIn = this.state.isLoggedIn;
return (
<div>
{isLoggedIn ? (
<LogoutButton onClick={this.handleLogoutClick} />
) : (
<LoginButton onClick={this.handleLoginClick} />
)}
</div>
);
}
คุณยังสามารถจัดการกับมันได้ภายในฟังก์ชัน render แต่ก่อนที่จะส่งคืน jsx
if (isLoggedIn) {
button = <LogoutButton onClick={this.handleLogoutClick} />;
} else {
button = <LoginButton onClick={this.handleLoginClick} />;
}
return (
<div>
<Greeting isLoggedIn={isLoggedIn} />
{button}
</div>
);
นอกจากนี้ยังควรกล่าวถึงสิ่งที่ ZekeDroid นำเสนอในความคิดเห็น หากคุณแค่ตรวจสอบเงื่อนไขและไม่ต้องการแสดงโค้ดบางส่วนที่ไม่เป็นไปตามนั้นคุณสามารถใช้ไฟล์&& operator
.
return (
<div>
<h1>Hello!</h1>
{unreadMessages.length > 0 &&
<h2>
You have {unreadMessages.length} unread messages.
</h2>
}
</div>
);