【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错误提示插件

相关推荐
晚霞的不甘8 小时前
Flutter for OpenHarmony天气卡片应用:用枚举与动画打造沉浸式多城市天气浏览体验
前端·flutter·云原生·前端框架
xkxnq8 小时前
第五阶段:Vue3核心深度深挖(第74天)(Vue3计算属性进阶)
前端·javascript·vue.js
三小河9 小时前
Agent Skill与Rules的区别——以Cursor为例
前端·javascript·后端
Hilaku9 小时前
不要在简历上写精通 Vue3?来自面试官的真实劝退
前端·javascript·vue.js
三小河9 小时前
前端视角详解 Agent Skill
前端·javascript·后端
Aniugel9 小时前
单点登录(SSO)系统
前端
鹏多多9 小时前
移动端H5项目,还需要react-fastclick解决300ms点击延迟吗?
前端·javascript·react.js
serioyaoyao9 小时前
上万级文件一起可视化,怎么办?答案是基于 ParaView 的远程可视化
前端
万少9 小时前
端云一体 一天开发的元服务-奇趣故事匣经验分享
前端·ai编程·harmonyos
WindrunnerMax9 小时前
从零实现富文本编辑器#11-Immutable状态维护与增量渲染
前端·架构·前端框架