React中条件渲染的常见方法总结

 更新时间:2024年01月03日 08:21:49   作者:小九九爱学习83645  
条件渲染在React开发中非常重要的功能,它允许开发人员根据条件控制渲染的内容,在创建动态和交互式用户界面方面发挥着至关重要的作用,本文总结了常用的的条件渲染方法,需要的朋友可以参考下

1.If-else

if-else是一种控制流程的简单方法,在控制渲染中能发挥很好的作用。

2.三元运算符(?)

三元运算符是条件如果为真则返回一个值,如果为假则返回另一个值,

在react中使用的非常广泛,在条件比较简单和内容较少的情况下非常实用,并且语法简洁。

3.逻辑与(&&)

在只关注一种条件结果的情况下,使用逻辑与比三元运算符更简洁。

4.空值合并运算符(??)

当空合并运算符 ( ??) 前面的值为null或undefined, 会返回问号右边的表达式。

在组件内,我们使用空合并运算符 (??) 来处理可能agenullundefined的情况。如果user.age缺少,该userAge变量默认为“未知”,然后在渲染的输出中使用。这确保了即使年龄数据不存在,组件也可以优雅地处理这种数据缺失。

5.Switch Case 语句

switch/case非常适合在 React 中不同条件导致导致不同渲染,确保代码的可维护且可读性。

6.策略方案

该方案可以作为Switch Case的替代者,

甚至可以使用true和false来做key来处理一些特定场景,在下面的场景中isWorkDay,isSunday,isFestival都可能是true,所以这里产生了优先级,可以利用这里的优先级来做一些条件渲染。

高阶条件渲染场景

掌握基本常用方法后,还会遇到需要更复杂解决方案的场景。

7.ErrorBoundry

ErrorBoundry可以捕获其子组件树中的 JavaScript 错误、记录这些错误,并显示兜底UI 而不是崩溃的组件树的组件。

在这里需要捕获到错误的时候依据条件渲染用户自定义的兜底UI。

8.高阶组件 (HOC)

HOC 是包装组件的函数,可以根据收到的 props 有条件地渲染组件,从而提供更灵活的方式来跨组件共享逻辑。

想象一下,有一个功能只有拥有高级帐户的用户才能看到。我们将创建一个 HOC 来检查用户的帐户类型并有条件地相应地呈现组件。

高阶组件withPremiumFeature中根据参数判断展示内容

9.render props

render props是将函数作为props传递给组件,该函数中可以根据条件判断决定UI展示。

在这个例子中,该UserOnlineStatus组件负责确定用户的在线状态,但不直接渲染UI。相反,它将渲染委托给一个 prop(render prop),这是一个由父组件传递的函数。函数 ( renderStatus) 获取isOnline状态并根据此信息决定渲染内容。

条件渲染的最佳实践

  • If/Else 语句: 使用传统的 if/else 语句进行简单的分支逻辑渲染组件,简单易读。当条件简单且有限时,if/else 语句通常是一个不错的选择。
  • 三元运算符 (?): 三元运算符非常适合简洁的条件渲染,特别当需要基于单个条件渲染两个组件之一时。它非常适合希望保持 JSX 干净且可读的简单场景。
  • 逻辑 AND (&&): 当只想条件为真渲染组件时,逻辑 AND 运算符是一个干净而高效的选择。
  • 空值合并运算符 (??): 使用空值合并运算符为 null 或未定义的操作数提供默认值。当您需要确保组件不会因丢失数据而损坏时,它特别有用。即使数据可能不存在,该技术也能确保稳健的渲染。
  • Switch Case 语句: 当您有多个条件导致不同的渲染时可使用 switch case 语句。这种方法可以保持代码的组织性和可读性,使其成为具有多个条件分支的复杂场景的绝佳选择。
  • 策略方案: 可维护性高,但是条件复杂的时候会比较麻烦。

针对特定用例的高级技术:

  • ErrorBoundry: 主要应用在捕获组件树的错误并展示兜底UI的场景。
  • 高阶组件 (HOC): HOC 对于封装和重用组件逻辑有用,并且在想要根据 props 或用户特定条件渲染组件的场景中尤其有用
  • render Props: 当您需要对渲染进行细粒度控制并希望在组件之间共享渲染逻辑时,render props模式是一个不错的选择

注意事项

1. 过度使用三元运算符:

  • 嵌套的三元运算符的可读性堪忧,如果发现使用了嵌套三元运算符,这可能表明应该重构为单独的组件或使用更合适的方法,例如if语句或创建新的渲染函数。

2.滥用逻辑&&造成短路:

  • 处理数字0或者空字符串时要小心。例如,如果 count 为 0,{count && <Component />}则将无法渲染,因为 0 在 JavaScript 中是一个假值。

3. 滥用空值合并运算符??:不要将它与逻辑||运算符混淆。value ?? alternative如果“value”为空或未定义,则表达式仅显示“alternative”,而value || alternative对于每个假值(例如,''、0、false)则显示“alternative”。

以上就是React中条件渲染的常见方法总结的详细内容,更多关于React条件渲染的资料请关注脚本之家其它相关文章!

相关文章

  • React之使用useState异步刷新的问题

    React之使用useState异步刷新的问题

    这篇文章主要介绍了React之使用useState异步刷新的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • 一文详解React Redux设计思想与工作原理

    一文详解React Redux设计思想与工作原理

    最近看项目中使用了 Redux, 便尝试了解一波 Redux 的设计思想与工作原理,所以本文详细的给大家介绍了Redux设计思想与工作原理,需要的朋友可以参考下
    2023-09-09
  • React中编写CSS实例详解

    React中编写CSS实例详解

    这篇文章主要为大家介绍了React中编写CSS实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • 可定制react18 input otp 一次性密码输入组件

    可定制react18 input otp 一次性密码输入组件

    这篇文章主要为大家介绍了可定制react18 input otp 一次性密码输入组件,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • React组件重复渲染的成因与解决方法

    React组件重复渲染的成因与解决方法

    React 组件的重复渲染是开发中常见的性能问题之一,尤其是在大型应用中,组件的频繁渲染会导致性能瓶颈,本文将探讨 React 组件重复渲染的常见原因,并提供优化策略,帮助开发者提升应用性能,需要的朋友可以参考下
    2025-03-03
  • React中使用echarts-for-react的方法示例

    React中使用echarts-for-react的方法示例

    echarts-for-react则是ECharts在React生态中的官方封装组件,它让开发者能够轻松地在React应用中集成ECharts图表,本文就来介绍一下echarts-for-react的使用,感兴趣的可以了解一下
    2025-03-03
  • React中useTransition钩子函数的使用详解

    React中useTransition钩子函数的使用详解

    React 18的推出标志着React并发特性的正式到来,其中useTransition钩子函数是一个重要的新增功能,下面我们就来学习一下useTransition钩子函数的具体使用吧
    2024-02-02
  • React报错解决之ref返回undefined或null

    React报错解决之ref返回undefined或null

    最近使用react做个滚动监听获取更多数据效果,当想获取dom时发现怎么也获取不到,下面这篇文章主要给大家介绍了关于React报错解决之ref返回undefined或null的相关资料,需要的朋友可以参考下
    2022-08-08
  • 为什么说form元素是React的未来

    为什么说form元素是React的未来

    这篇文章主要介绍了为什么说form元素是React的未来,本文会带你聊聊React围绕form的布局与发展,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • React中ES5与ES6写法的区别总结

    React中ES5与ES6写法的区别总结

    这篇文章主要总结介绍了关于React中ES5与ES6的写法区别,文中介绍的非常详细,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-04-04

最新评论