【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教程

相关推荐
化作繁星11 分钟前
如何在 React 中测试高阶组件?
前端·javascript·react.js
初遇你时动了情14 分钟前
react module.scss 避免全局冲突类似vue中scoped
vue.js·react.js·scss
Au_ust18 分钟前
千峰React:函数组件使用(2)
前端·javascript·react.js
GAMESLI-GIS1 小时前
【WebGL】fbo双pass案例
前端·javascript·webgl
来一碗刘肉面1 小时前
React - ajax 配置代理
前端·react.js·ajax
bin91531 小时前
DeepSeek 助力 Vue 开发:打造丝滑的二维码生成(QR Code)
前端·javascript·vue.js·ecmascript·deepseek
@LitterFisher1 小时前
Excell 代码处理
前端·javascript·excel
十八朵郁金香3 小时前
【JavaScript】深入理解模块化
开发语言·javascript·ecmascript
YaHuiLiang3 小时前
一切的根本都是前端“娱乐圈化”
前端·javascript·代码规范
界面开发小八哥3 小时前
可视化工具SciChart如何结合Deepseek快速创建一个React仪表板?
react.js·信息可视化·数据可视化·原生应用·scichart