React 条件渲染

开发环境:React+ts+antd

通常你的组件会需要根据不同的情况显示不同的内容。在 React 中,你可以通过使用 JavaScript 的 if 语句、&& 和 ? : 运算符来选择性地渲染 JSX。

例子

我们在满足 isPacked={true} 条件的物品清单旁加上一个勾选符号✔。

javascript 复制代码
import React from "react";

interface ListPro {
    name:string,
    isPacked:boolean,
}

const Item:React.FC<ListPro> =({name,isPacked})=>{
	if (isPacked) {
        return <li className="item">{name} ✔</li>;
    }
    return <li className="item">{name}</li>;
}

const App: React.FC = () => {
    return (
        <div>
            <h1>Sally Ride 的行李清单</h1>
            <Item
                isPacked={true}
                name="宇航服"
            />
            <Item
                isPacked={true}
                name="带金箔的头盔"
            />
            <Item
                isPacked={false}
                name="Tam 的照片"
            />
        </div>
    )
}
export default App;

此条件判断处可以使用三目运算,或者是与运算符(&&), 运行结果是一样的

javascript 复制代码
return (
        <li className="item">
            {isPacked ? name + ' ✔' : name} 
        </li>
    );
javascript 复制代码
 return (
        <li className="item">
            {name} {isPacked && '✔'}
        </li>
    );

注意:切勿将数字放在 && 左侧.

JavaScript 会自动将左侧的值转换成布尔类型以判断条件成立与否。然而,如果左侧是 0,整个表达式将变成左侧的值(0),React 此时则会渲染 0 而不是不进行渲染。

例如,一个常见的错误是 messageCount &&

New messages
。其原本是想当 messageCount 为 0 的时候不进行渲染,但实际上却渲染了 0。

为了更正,可以将左侧的值改成布尔类型:messageCount > 0 &&

New messages

接下来我们给未完成的物品加上图标,当 isPacked 不为 true 时,使用条件运算符 (cond ? a : b) 来渲染 ❌

javascript 复制代码
return (
        <li className="item">
            {isPacked ? name + '✔' : name + '❌'}
        </li>
    );

运行结果如下:

例子是参考React官方文档教程,不同的是我这里使用TS来写

相关推荐
雪碧聊技术3 小时前
前端项目代码发生改变,如何重新部署到linux服务器?
前端·vue3·centos7·代码更新,重新部署
liulilittle3 小时前
C++ 浮点数封装。
linux·服务器·开发语言·前端·网络·数据库·c++
wordbaby3 小时前
Expo 进阶指南:赋予 TanStack Query “原生感知力” —— 深度解析 AppState 与 NetInfo
前端·react native
Moment3 小时前
从美团全栈化看 AI 冲击:前端转全栈,是自救还是必然 🤔🤔🤔
前端·后端·面试
天问一3 小时前
使用 Vue Router 进行路由定制和调用的示例
前端·javascript·vue.js
韩立学长5 小时前
【开题答辩实录分享】以《基于Vue的非遗文化知识分享平台的设计与实现》为例进行选题答辩实录分享
前端·javascript·vue.js
优弧5 小时前
离开舒适区100天,我后悔了吗?
前端·后端·面试
胡gh5 小时前
css的臂膀,前端动效的利器,还是布局的“隐形陷阱”?
前端·css·html
灵感菇_5 小时前
Flutter Riverpod 完整教程:从入门到实战
前端·flutter·ui·状态管理
用户21411832636025 小时前
紧急修复!Dify CVE-2025-55182 高危漏洞,手把手教你升级避坑
前端