React(7)

hooks

封装自定义hook通用思路

//1.声明一个以use打头的函数

// 2.在函数体内封装可复用的逻辑(只要是可复用的逻辑)

// 3.把组件中用到的状态或者回调return出去(以对象或者数组)

// 4.在哪个组件中要用到这个逻辑,就执行这个函数,解构出来状态和回调进行使用

javascript 复制代码
import {  useState } from "react";
function Son() {
  return <div>son组件</div>;
}
// 自定义hooks 
// 注意函数的写法为匿名函数还是声明函数
function useTaggle() {
  const [Show, setShow] = useState(true);
  function taggle (){setShow(!Show)} 
  return {
    Show,
    taggle,
  };
}
function App() {
  // 在组件中使用需要进行结构
  const { Show, taggle } = useTaggle();
  // const [Show, setShow] = useState(true);
  // const taggle=setShow(!Show)
  return (
    <div className="App">
      {Show && <Son></Son>}
      <button onClick={taggle}>卸载组件</button>
    </div>
  );
}

export default App;

使用规则

只能在组件中或者其他自定义HOOK函数中使用

只能在组件的顶层调用 不能在if for 其他函数中使用

相关推荐
喵了几个咪6 分钟前
Go + Vue/React 全栈开发实践
vue.js·react.js·golang·elementplus·vben·go-kratos
陈随易9 分钟前
Redis数据结构速通
前端·后端·程序员
流年如夢12 分钟前
类和对象(中)
开发语言·javascript·ajax·ecmascript
络合白泽17 分钟前
Linux Mint Firefox 标题栏如何关闭
前端·firefox
渣渣xiong18 分钟前
从零开始:前端转型AI agent直到就业第十八天-第五十六天
前端·agent·ai编程
Moment18 分钟前
你都写这么久代码了,为什么不考虑做一个自己的小程序❓❓❓
前端·后端·面试
神所夸赞的夏天18 分钟前
安装 HTTP 客户端 npm install axios报错:“code EPERM“解决方法
前端·npm·node.js
憧憬成为web高手9 小时前
ACTF 12307复现
前端·bootstrap·html
wordbaby9 小时前
Axios 上传大文件崩溃:鸿蒙 RNOH 下 XHR 返回空响应头引发的"假失败"
前端·react native
wordbaby10 小时前
React Native 列表分页实战:下拉刷新与上拉加载的工程化方案
前端·react native