【React】react hooks的使用规则

1. 使用规则

1.1 反例
javascript 复制代码
import { useState } from 'react'

// 错误1
// useToggle('')

function Son() {
  return <div>子组件</div>
}

function useToggle() {
  const [isShow, setIsShow] = useState(true)
  function toggle() {
    setIsShow(!isShow)
  }
  return {
    isShow,
    toggle
  }
}

function App() {
  const { isShow, toggle } = useToggle()
  if (isShow) {
    // 错误2
    useState('')
  }
  return (
    <div className="App">
      {isShow && <Son />}
      <button onClick={toggle}>点击我,隐藏子组件</button>
    </div>
  );
}

export default App;

报错:

控制台、浏览器都会有报错,也可以下载vscode错误提示插件

相关推荐
FakeOccupational10 分钟前
【树莓派 002】 RP2040 实现示波器 PIO来驱动 ADC10080 并抓取数据方案+ 内置12-bitADC&DMA&网页前端可视化方案
前端
DJ斯特拉16 分钟前
Vue工程化
前端·javascript·vue.js
秋深枫叶红17 分钟前
嵌入式第三十五篇——linux系统编程——exec族函数
linux·前端·学习
LinDon_23 分钟前
【vue2form表单中的动态表单校验】
前端·javascript·vue.js
一水鉴天33 分钟前
整体设计 之28 整体设计 架构表表述总表的 完整程序(之27 的Q268 )(codebuddy)
java·前端·javascript
DsirNg39 分钟前
使用 SSE 单向推送实现 系统通知功能
前端·javascript
IT_陈寒1 小时前
SpringBoot 3.2 实战:用这5个新特性让你的API性能提升40%
前端·人工智能·后端
霍理迪1 小时前
HTML初相识
前端·html
恋猫de小郭1 小时前
Android 宣布 Runtime 编译速度史诗级提升:在编译时间上优化了 18%
android·前端·flutter