前端学习之——react篇(条件渲染)

React 没有特殊的语法来编写条件语句,因此你使用的就是普通的 JavaScript 代码。例如使用 if 语句根据条件引入 JSX:

javascript 复制代码
let content;
if (isLoggedIn) {
  content = <AdminPanel />;
} else {
  content = <LoginForm />;
}
return (
  <div>
    {content}
  </div>
);

如果你喜欢更为紧凑的代码,可以使用 条件 ? 运算符。与 if 不同的是,它工作于 JSX 内部:

javascript 复制代码
<div>
  {isLoggedIn ? (
    <AdminPanel />
  ) : (
    <LoginForm />
  )}
</div>

当你不需要 else 分支时,你还可以使用 逻辑 && 语法

javascript 复制代码
<div>
  {isLoggedIn && <AdminPanel />}
</div>

所有这些方法也适用于有条件地指定属性。如果你对 JavaScript 语法不熟悉,你可以从一直使用 if...else 开始。

注意⚠️:

在上面的代码片段中,&& 是 JavaScript 中的逻辑与(AND)操作符。它用于在条件表达式中进行逻辑判断。

在这个特定的用法中,{isLoggedIn && <AdminPanel />} 表示如果 isLoggedIn 为真(即为 true),则渲染 <AdminPanel> 组件;否则,不进行渲染。

这种写法是一种简洁的条件渲染方式。当 isLoggedIn 为真时,表达式的结果为 <AdminPanel /> 组件,从而使其被渲染。当 isLoggedIn 为假时,表达式的结果为 false,因此不会渲染任何内容。

这种写法相当于以下的条件语句:

javascript 复制代码
<div>
  {isLoggedIn ? <AdminPanel /> : null}
</div>

使用 && 操作符的条件渲染方式可以帮助简化代码并提高可读性。

相关推荐
lichenyang4531 小时前
从零到一:用 Taro + React 搭建数据采集小程序
react.js·小程序·taro
神の愛6 小时前
左连接查询数据 left join
java·服务器·前端
大龄程序员狗哥6 小时前
第25篇:Q-Learning算法解析——强化学习中的经典“价值”学习(原理解析)
人工智能·学习·算法
南境十里·墨染春水7 小时前
linux学习进展 线程同步——互斥锁
java·linux·学习
nashane8 小时前
HarmonyOS 6学习:旋转动画优化与长截图性能调优——打造丝滑交互体验的深度实践
学习·交互·harmonyos·harmonyos 5
小码哥_常8 小时前
解锁Android嵌入式照片选择器,让你的App体验丝滑起飞
前端
华清远见IT开放实验室8 小时前
智能手表完整项目实现,比赛求职双向加分,基于嵌入式大赛推荐开发板(STM32U5)
stm32·单片机·嵌入式硬件·学习·智能手表·嵌入式大赛
炽烈小老头9 小时前
【 每天学习一点算法 2026/04/22】四数相加 II
学习·算法
郑寿昌9 小时前
IIoT本体迁移的领域扩展机制
服务器·前端·microsoft
uncle_ll9 小时前
LangChain基础学习笔记
笔记·学习·langchain·llm·rag