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 其他函数中使用

相关推荐
~央千澈~14 小时前
抖音弹幕游戏开发之第17集:添加日志系统·优雅草云桧·卓伊凡
linux·服务器·前端
JamesYoung797114 小时前
第一部分 — 基础知识 项目框架与文件布局
前端·chrome
孟健14 小时前
程序员就业率暴跌27.5%:我离开大厂5个月后,看懂了这件事
前端
卸任14 小时前
Electron判断是内置摄像头还是接摄像头
前端·react.js·electron
NEXT0615 小时前
普通函数与箭头函数的区别
前端·javascript·面试
Lao乾妈官方认证唯一女友:D15 小时前
wagmi使用方法
react.js·web3·wagmi
全马必破三15 小时前
Webpack知识点汇总
前端·webpack·node.js
NEXT0615 小时前
CommonJS 与 ES Modules的区别
前端·面试·node.js
TechFind15 小时前
如何为 AI Agent 写出完美的 SOUL.md 人格文件(2026指南)
javascript
猪头男15 小时前
【从零开始学习Vue|第八篇】深入组件——组件事件
前端