当前位置: 首页 > news >正文

react18自定义hook实现

概念:自定义 hook 是一种将组件逻辑提取到可复用函数中的方式,它允许你在多个组件中共享相同的状态和行为。自定义 hook 的本质上是一个普通的 JavaScript 函数,它可以使用 React 内部的 hook(如 useStateuseEffectuseContext 等)来管理组件逻辑。

例子:使用自定义 hook 来处理div的显示隐藏:

  • 创建一个hook.js 声明一个use打头的函数,在函数体内封装可复用的逻辑
  • 封装好后,把组件中用到的状态或者回调函数已对象的形式return出去

import React, { useState } from "react";

const useIsShow = () => {
  const [show, setShow] = useState(true);
  const isShow = () => {
    setShow(!show);
  };
  return {
    show,
    isShow,
  };
};

export default useIsShow;
  • 在哪个组件要用到这个逻辑,引入封装好的hook,解构出来状态或者回调函数进行使用

import React from "react";
import useIsShow from './hooks'

function App() {
  const {show,isShow} = useIsShow()
  return (
    <div className="App">
       {show && <div>div</div>}
       <button onClick={()=>{isShow()}}>切换</button>
    </div>
  );
}

export default App;

注:本人前端小白 ,如有不对的地方还请多多指教

相关文章:

  • 基于three进行数字孪生平台架构设计及应用实现
  • 【安卓逆向】逆向APP界面UI修改再安装
  • Git详解及常用命令
  • .NET Core MVC IHttpActionResult 设置Headers
  • 将 iOS 项目打包并运行到真实的 iPhone 设备
  • python实现基于文心一言大模型的sql小工具
  • 02.25 继承和多态
  • 【大模型系列】使用ollama本地运行千问2.5模型
  • [字节青训_AI对话框]SSE交互规范、自定义事件、前后端数据传递、状态监听、连接和断开详解
  • knife4j+springboot3.4异常无法正确展示文档
  • (论文)使用双频分析检测 AI 合成的语音
  • 【大厂AI实践】微软:基于预训练的自然语言生成在搜索与广告中的应用
  • 高一英语拓展词汇第二版
  • 基于ArcGIS Pro、R、INVEST等多技术融合下生态系统服务权衡与协同动态分析实践应用
  • Android构建系统 - 03 编译执行流程
  • Zemax OpticStudio 中的扩散器建模
  • Linux网络安全
  • 如何利用机器学习实现信用风险评分
  • 深度剖析Seata源码:解锁分布式事务处理的核心逻辑
  • 一文掌握 Playwright 的详细使用
  • 合肥做网站优化/株洲网页设计
  • 营销网站建设制作设计/百度手机助手网页
  • 哪里有网站模板下载/网络热词有哪些
  • 百度站长平台推出网站移动化大赛/沈阳seo排名优化软件
  • wordpress建什么站/seo白帽优化
  • 自主建设公司网站/杭州seo价格