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

相关推荐
得物技术9 分钟前
得物端智能视频封面推荐
前端·算法
smart_ljh10 分钟前
JS设计模式之单例原型
开发语言·javascript·设计模式
强壮的小白菜37 分钟前
npm和pnpm的区别
前端·npm·node.js
ybq1951334543141 分钟前
javaEE-11.javaScript入门
开发语言·javascript·ecmascript
无光末阳1 小时前
echarts 双Y轴,左右刻线对齐,封装
前端·vue.js
小钟H呀1 小时前
Git Cherry-Pick 使用教程:精准移植提交的利器
前端·git
用户88931993229741 小时前
Ant Design Vue 实现表格合并单元格并且可分页
前端
誰氵难浔1 小时前
解决微信小程序原生云开发退款报错“特约子商户商户号未授权服务商的产品权限”的问题
前端
前端郭德纲2 小时前
使用 React 16+Webpack 和 pdfjs-dist 或 react-pdf 实现 PDF 文件显示、定位和高亮
react.js·webpack·pdf
noravinsc2 小时前
This dependency was not found: * @logicflow/core/dist/LogicFlow.css
前端·css