首页 > 其他分享 >6个在React中使用的小技巧

6个在React中使用的小技巧

时间:2024-01-08 17:37:32浏览次数:34  
标签:语句 const 技巧 default React useState 使用 组件 return

这是一个可怕的问题,在 React 中,我们经常会编写条件语句来显示不同的视图,比如这个简单的例子。

const App = () => {
  return (
    <>
      {
        loading ? <Loading /> : <List>
      }
    </>
  )
}

但是,当项目的代码量足够大并且有很多 JSX 条件时,事情很快就会失控。代码变得非常混乱且可读性差。像下面这段代码,我真的没有勇气和信心去了解它的细节。

import React, { useState } from "react"

export default function ConditionDemo() {
  const [ loading ] = useState(false)
  const [ isLogin ] = useState(true)
  const [ hasAuth ] = useState(false)
  return (
    <>
      {
        loading ?
          <div className="loading">
            loading
          </div> :
          <div className="content">
            {
              isLogin ?
                (
                  hasAuth ?
                    <div className="has-permission">
                      has-permission
                    </div> :
                    <div className="no-permission">You have no permission to operate</div>
                ) :
                <div className="go-login">Please login first</div>
            }
          </div>
      }
    </>
  )
}

那么,在 React 中,我们可以通过哪些方式编写更具可读性和可维护性的代码呢?

1.使用三元运算符

三元运算符更适合需要少量条件判断的场景。

如果条件分支很多,就会发生上面例子的灾难。

例如,要在移动设备上显示一个 Mobile 组件,而在其他屏幕上显示另一个组件,可以使用三元表达式来实现:

export default function AppTernaryExpressions() {
  const isMobilePhone = true
  return (
    <>
      { isMobilePhone ? <MobileComp /> : <PcComp /> }
    </>
  )
}

2.使用“&&”简化三元运算符

有时我们可以使用“&&”来简化三元表达式,比如下面的代码。

show ? <ShowComp /> : null

&&

!!show && <ShowComp />

为什么要使用两个感叹号将显示转换为布尔值?这个我会在明天的文章中跟大家再分享一篇这个内容的文章。

3.使用“if”语句

如果有数据,则显示 List 组件。如果没有数据,则不显示任何内容。使用 if 语句也是一个不错的选择。

export default function AppIf() {
  const { list } = useList()

  if (!list) {
    return null
  }

  return (
    <List list={list} />
  )
}

当然,发送请求并不总是成功,也可能失败。我们可以添加一些 if 分支来控制不同的逻辑。

export default function AppIf() {
  const { isLoading, isError, list } = useList()

  if (isLoading) {
    return <div>Loading...</div>
  }

  if (isError) {
    return <div>Error...</div>
  }

  return <List list={list} />
}

4.使用“switch”

过多的 if 语句会导致组件混乱,因此,我们可以将多个条件提取到包含 switch 语句的单独组件中。

让我们看一个简单的菜单切换组件:

const MenuItem({ menu })  => {
  switch (menu) {
    case 1:
      return <Users />
    case 2:
      return <Chats />
    case 3:
      return <Rooms />
    default:
      return null
  }
}

export default function Menu() {
  const [menu, setMenu] = React.useState(1)
  const toggleMenu = () => {
    setMenu((m) => {
      if (m === 3) return 1
      return m + 1
    })
  }
  return (
    <>
      <MenuItem menu={ menu } />
      <button onClick={ toggleMenu }>toggle menu</button>
    </>
  )
}

可以看到,使用‘switch’可以很方便的表达‘menu’和组件的对应关系。

5.使用枚举

如果我们需要根据用户的不同状态显示Foo、Bar、Default三个组件,枚举会比if语句更优雅。

const Foo = () => {
  return <div>foo</div>
}
const Bar = () => {
  return <div>bar</div>
}
const Default = () => {
  return <div>default</div>
}
const statusMap = {
  foo: <Foo />,
  bar: <Bar />,
  default: <Default />
}
const App = () => {
  const [status] = useState('default')
  return (
    statusMap[status]
  )
}

6.使用 JSX 控制语句

JSX 控制语句库扩展了 JSX 的功能,让你可以直接使用 JSX 实现条件渲染。

让我们举个例子。

export default function App(props) {
  const [ hasLogin ] = useState(false)
  //...
  return (
    <Choose>
      <When condition={ hasLogin }>
        <button>Logout</button>
      </When>
      <When condition={ !hasLogin }>
        <button>Login</button>
      </When>
    </Choose>
  )
}

标签:语句,const,技巧,default,React,useState,使用,组件,return
From: https://blog.51cto.com/u_15739596/9147469

相关文章

  • 使用 Jamf Pro 和 Okta 工作流程实现自动化苹果设备管理
    Jamf的销售工程师VincentBonnin与Okta的产品经理EmilyWendell一起介绍了JNUC2021的操作方法会议。它们涵盖了Okta工作流程(OktaWorkflow),并在其中集成了JamfPro,构建了一些工作流程,并提供了几个用例。Okta工作流程和JamfPro这个使用OktaWorkflows和JamfPro进行苹果设备管理的J......
  • 使用VBScript清理%AppData%\Microsoft\InputMethod\Chs下的UDP*.tmp文件
    目录代码使用方法话题来源彩蛋——Windows操作系统下到底有多少种脚本语言?代码'VBScripttolistUDP*.tmpfilesandaskuserfordeletionOptionExplicit'DeclarevariablesDimWSHShell,FSO,TargetFolder,FileCollection,FileDimTargetPattern,FilesToDelete,Fi......
  • LINE网页版使用方法(内含LINE网页版特点总结)
    如果想要在电脑上使用LINE,但是又觉得下载客户端很累赘的话,LINE网页版是你最好的选择。但是LINE网页版相对于其他平台来说使用方式比较少。所以今天就来讲讲,我们有什么方式可以在电脑中使用LINE。LINE网页版使用方法1.需要使用Chrome浏览器,并选择【扩展程序】中的【访问Chrome应用商......
  • stm32学习总结:5、Proteus8+STM32CubeMX+MDK仿真串口并使用串口打印日志(注意重定向prin
    stm32学习总结:5、Proteus8+STM32CubeMX+MDK仿真串口并使用串口打印日志(注意重定向printf到串口打印的问题)文章目录stm32学习总结:5、Proteus8+STM32CubeMX+MDK仿真串口并使用串口打印日志(注意重定向printf到串口打印的问题)一、前言二、资料收集三、注意事项四、STM32CubeMX配置五、......
  • 日志:已知某天是星期几,不使用时间函数计算一个日期是星期几
    背景:2003年记录的小程序已知某天是星期几,不使用时间函数计算一个日期是星期几。不知道谁写的函数,有些复杂了,但运行正常。觉得先计算已知日期当年1月1号是星期几,再加上间隔年份+闰年数+所求日期是一年中的第几天比较简单。代码#include<iostream>#include<conio.h>usingnamesp......
  • 使用anaconda创建爬虫spyder工程
    1.由于每个工程使用的环境都可能不一样,因此一个好的习惯就是不同的工程都创建属于自己的环境,在anaconda中默认的环境是base,我们现在来创建一个名为spyder的环境,专门用于爬虫工程://括号中名字,代表当前的环境(base)dragon@machine:$condacreate--name=spyder2.激活环境//环境从......
  • 使用anaconda创建notebook工程
    1.由于每个工程使用的环境都可能不一样,因此一个好的习惯就是不同的工程都创建属于自己的环境,在anaconda中默认的环境是base://括号中名字,代表当前的环境(base)dragon@machine:$condacreate--name=example2.激活环境//环境从base切换到example(base)dragon@machine:$condaa......
  • 「微服务」Saga 模式 如何使用微服务实现业务事务-第二部分
    在上一篇文章中,我们看到了实现分布式事务的一些挑战,以及如何使用Event/Choreography方法实现Saga的模式。在本文中,我们将讨论如何通过使用另一种类型的Saga实现(称为Command或Orchestration)来解决一些问题,如复杂事务或事件的循环依赖性。Saga的命令/编曲序列逻辑在编曲方法中,我们......
  • 【MLOps】使用Ray缩放AI
    Ray正在人工智能工程领域崭露头角,对扩展LLM和RL至关重要Spark在数据工程中几乎是必不可少的。Ray正在人工智能工程领域崭露头角。雷是伦敦大学学院Spark的继任者。Spark和Ray有很多相似之处,例如用于计算的统一引擎。但Spark主要专注于大规模数据分析,而Ray则是为机器学习应用程序设......
  • Java 打maven包 可以使用java -jar 运行
    有时候我们想打一个jar包像springboot项目一样运行javajar来运行,但是直接使用maven引入相关的依赖直接打包无法使用。这时需要在pom.xml中添加一个plugin   <plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-assembly-pl......