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

相关推荐
阿奇__几秒前
前端模块化指南:CJS 与 ESM 的区别与混用
前端
北寻北爱3 分钟前
面试篇-webpack+vite
前端
Kinghiee3 分钟前
使用webpack构建vue3 ssr
前端·webpack·node.js·vue3ssr
wuhen_n7 分钟前
回溯算法入门 - LeetCode经典回溯算法题
前端·javascript·算法
xcs1940514 分钟前
前端 vue this.$nextTick(() => {
前端·javascript·vue.js
广州华水科技16 分钟前
如何在基础设施安全中有效实现GNSS位移监测的应用?
前端
大漠_w3cpluscom19 分钟前
前端怎么提升自己的CSS编写能力?
前端
我是若尘21 分钟前
大数据量渲染优化:分批渲染技术详解
前端
ruanCat21 分钟前
pnpm 踩坑实录:用 public-hoist-pattern 拯救被严格隔离坑掉的依赖
前端·npm·node.js
yuki_uix22 分钟前
渲染优化三件套:React.memo、useMemo、useCallback 的使用边界
前端·react.js