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

相关推荐
java1234_小锋1 分钟前
一周学会Flask3 Python Web开发-SQLAlchemy查询所有数据操作-班级模块
开发语言·前端·python
OpenTiny社区20 分钟前
OpenTiny技术直播讲师招募:与开源同行,点亮技术影响力!
前端·vue.js·低代码
还是鼠鼠28 分钟前
Node.js--CommonJS 模块化规范详解:使用方法、缓存机制与模块解析
前端·javascript·vscode·缓存·node.js·web
冰夏之夜影1 小时前
【css酷炫效果】纯CSS实现大风车旋转效果
前端·css
机器瓦力1 小时前
开发突围:该换电脑了
flutter·react.js·程序员
Honeysea_701 小时前
React 和 Vue 框架概念及区别
前端·vue.js·react.js
rookiefishs1 小时前
如何nodejs中使用winston库记录本地日志?
前端·javascript·后端
冰夏之夜影1 小时前
【css酷炫效果】纯CSS实现3D翻转卡片动画
前端·css
一朵忧伤的蔷薇1 小时前
css知识点
前端·css
henujolly1 小时前
手写发布订阅模式
前端