【React】自定义hook函数

1. 概念

本质:函数

2. 例子

  • 需求:实现点击按钮的展示与隐藏子组件
2.1 不封装直接实现
javascript 复制代码
import { useState } from 'react'
function Son() {
  return <div>子组件</div>
}

function App() {
  const [isShow, setIsShow] = useState(true)
  function toggle() {
    setIsShow(!isShow)
  }
  return (
    <div className="App">
      {isShow && <Son />}
      <button onClick={toggle}>点击我,隐藏子组件</button>
    </div>
  );
}

export default App;
2.2 封装自定义hook实现
javascript 复制代码
import { useState } from 'react'
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()
  return (
    <div className="App">
      {isShow && <Son />}
      <button onClick={toggle}>点击我,隐藏子组件</button>
    </div>
  );
}

export default App;

3 总结(封装自定义hook通用思路)

  1. 声明一个use开头的函数
  2. 在函数体内封装可复用的逻辑
  3. 把组件中用到的状态或者回调return出去(以对象或者数组的形式)
  4. 在哪个组件中要用到这个逻辑,就执行这个函数,解构出状态和回调进行使用
4 参考

黑马程序员react教程

相关推荐
Alice-YUE11 分钟前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀1 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
莎士比亚的文学花园2 小时前
Linux驱动开发(3)——设备树
开发语言·javascript·ecmascript
01漫游者2 小时前
JavaScript函数与对象增强知识
开发语言·javascript·ecmascript
threelab4 小时前
Three.js 代码云效果 | 三维可视化 / AI 提示词
开发语言·javascript·人工智能
yqcoder6 小时前
JavaScript 柯里化:把“大餐”拆成“小炒”的艺术
开发语言·javascript·ecmascript
每天吃饭的羊6 小时前
JSZip的使用
开发语言·javascript
前端老石人6 小时前
前端开发中的 URL 完全指南
开发语言·前端·javascript·css·html
不可能的是7 小时前
从 /simplify 指令深挖 Claude Code 多 Agent 协同机制
javascript
Rkgua7 小时前
事件流模型是什么和DOM事件模型等关系
javascript