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

相关推荐
会飞的战斗鸡4 分钟前
JS中的链表(含leetcode例题)
javascript·leetcode·链表
方也_arkling38 分钟前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
qq_177767371 小时前
React Native鸿蒙跨平台剧集管理应用实现,包含主应用组件、剧集列表、分类筛选、搜索排序等功能模块
javascript·react native·react.js·交互·harmonyos
qq_177767371 小时前
React Native鸿蒙跨平台自定义复选框组件,通过样式数组实现选中/未选中状态的样式切换,使用链式调用替代样式数组,实现状态驱动的样式变化
javascript·react native·react.js·架构·ecmascript·harmonyos·媒体
web打印社区1 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
烬头88212 小时前
React Native鸿蒙跨平台采用了函数式组件的形式,通过 props 接收分类数据,使用 TouchableOpacity实现了点击交互效果
javascript·react native·react.js·ecmascript·交互·harmonyos
Amumu121382 小时前
Vuex介绍
前端·javascript·vue.js
2601_949809592 小时前
flutter_for_openharmony家庭相册app实战+相册详情实现
javascript·flutter·ajax
qq_177767372 小时前
React Native鸿蒙跨平台通过Animated.Value.interpolate实现滚动距离到动画属性的映射
javascript·react native·react.js·harmonyos
2601_949833392 小时前
flutter_for_openharmony口腔护理app实战+饮食记录实现
android·javascript·flutter