Raect中自定义hook

一、自定义Hook

自定义Hook:将一些常用的、跨越多个组件的Hook功能,抽离出去形成一个函数,该函数就是自定义Hook,自定义Hook,由于其内部需要使用Hook功能,所以它本身也需要按照Hook的规则实现:

  1. 函数名必须以use开头
  2. 调用自定义Hook函数时,应该放到顶层

例如:

很多组件都需要在第一次加载完成后,获取所有学生数据,然后设置状态。

//useAllStudents
import { useState, useEffect } from 'react'
import { getAllStudents } from "../components/services/student"/*** 当组件首次加载完成后,获取所有学生数据*/
export default function useAllStudents() {const [students, setStudents] = useState([])useEffect(() => {(async () => {const stus = await getAllStudents();setStudents(stus);})();}, [])return students;
}
import React from 'react'
import useAllStudent from './Hooks/useAllStudents';function Test() {const stus = useAllStudent();console.log('stus',stus)// 第一次为[],第二次为真实请求的数据const list = stus.map(it => <li key={it.id}>{it.name}</li>)return <ul>{list}</ul>
}
export default function App() {return (<div><Test /></div>)
}

注意,执行useAllStudent相当于是将

const [students, setStudents] = useState([])useEffect(() => {(async () => {const stus = await getAllStudents();setStudents(stus);})();}, [])return students;

这段代码写在了Test这个组件中,第一次stus为空数组,当通过接口请求到真实数据后,执行了setStudents方法(设置了状态),stus就有值了,所以组件会重新渲染。

使用自定义hook不用考虑那么多,只要调用它就获取到了真实数据,否则会陷入困惑中。
若其他组件也需要学生数据,直接调用即可useAllStudent即可。

若想在类组件中实现这个功能,就需要借助高阶组件了。

import React from 'react'
import useAllStudent from './Hooks/useAllStudents';
function withAllStudents(comp){return class AllStudentsWrapper extends React.Component{state = {stus:[],}async componentDidMount (){const stus = await getAllStudents();this.setState({stus});return <comp {...this.props} stus ={this.state.stus}></comp>}}
}
function Test(props) {const list = props.status.stus.map(it => <li key={it.id}>{it.name}</li>)return <ul>{list}</ul>
}
const TestStudents = withAllStudents(Test);export  default function App(){
return (<div><TestStudents/> </div>
)
}

使用高阶组件会麻烦一些,会导致组件的层级嵌套很多,有了hook之后,就是个简单的函数调用。若有其他事情,调用其他自定义hook即可,拆分的就很细了。

之前类组件中在componentDidmount中可能要做很多事情,比如获取数据,设置页面标题,启动定时器。设置一些真实的dom元素,这时使用自定义hook就可以抽离出去,每个hook中都可以实现单一的功能。每个hook中可以有自己的副作用,状态等等。

2.很多组件都需要在第一次加载完成后,启动一个计时器,然后在组件销毁时卸载。

使用Hook的时候,如果没有严格按照Hook的规则进行,eslint的一个插件(eslint-plugin-react-hooks)会报出警告。如何忽略?
/* eslint “react-hooks/exhaustive-deps”: “off” */

Timer.js

//Timer
/* eslint "react-hooks/exhaustive-deps": "off" */
import { useEffect } from "react"/*** 组件首次渲染后,启动一个Interval计时器* 组件卸载后,清除该计时器*/
export default (func, duration) => {useEffect(() => {const timer = setInterval(func, duration)return () => {clearInterval(timer);}}, [])
}
import React,{useState} from 'react'
import useTimer from "./Hooks/useTimer"function Test(props) {useTimer(()=>{console.log('Test组件')},1000);return <h1>Test组件</h1>
}
export default function App() {const [visible, setVisible] = useState(true)return (<div>{visible && <Test/>}<button onClick={()=>{setVisible(!visible);}}>点击</button>// 点击隐藏or显示,隐藏后定时器就会停止,显示后定时器又会出现</div>)
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/604059.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【华为OD真题 Python】攀登者2

文章目录 题目描述示例1输入输出说明示例2输入输出说明实现代码题目描述 攀登者喜欢寻找各种地图,并且尝试攀登到最高的山峰。 地图表示为一维数组,数组的索引代表水平位置,数组的高度代表相对海拔高度。其中数组元素0代表地面。 例如[0,1,4,3,1,0,0,1,2,3,1,2,1,0], 代表…

linux进程管理工具的使用(supervisorctl、systemd、init.d、Upstart、Monit、runit、Daemontools)

1、supervisorctl&#xff1a; 这是Supervisor提供的命令行客户端&#xff0c;Supervisor是一个进程控制系统。它用于在UNIX类操作系统上控制和监视进程。它通常用于服务器环境中管理长时间运行的进程。 Supervisor 是一个用于监控和控制 UNIX 系统上的进程的程序。它不是大多…

向量数据库:usearch的简单使用+实现图片检索应用

usearch的简单使用 usearch是快速开源搜索和聚类引擎&#xff0c;用于C、C、Python、JavaScript、Rust、Java、Objective-C、Swift、C#、GoLang和Wolfram &#x1f50d;中的向量和&#x1f51c;字符串 // https://github.com/unum-cloud/usearch/blob/main/python/README.md …

第7章-第5节-Java中的比较器comparator和泛型的简单说明

1、 引入 上个章节中我们在使用TreeSet保存自定义数据类型的时候&#xff0c;类必须要实现Comparable这个接口&#xff0c;然后重写CompareTo这个方法&#xff0c;这个必须是在具体的自定义类内部去写&#xff0c;有时不方便&#xff0c;每遇到一个都要在那个类内部去写这个Co…

vs c++ qt 叫请求的json 输出到输出终端

1 接收数据 std::string response ""; //设置数据接收函数 curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, Utils::req_reply); // 设置写入数据的缓冲区 curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void*)&response); 2 打印 数据类型 qDebug() << &q…

10-单例模式(Singleton)

意图 保证一个类只有一个实例&#xff0c;并提供一个访问它的全局访问点 实现 1 懒汉式&#xff0c;线程不安全 public class Singleton { private static Singleton instance; private Singleton (){} public static Singleton getInstance() { if (instance null) {…

第7章-第4节-Java中的Set集合和自然排序compareble

1、HashSet&#xff1a; 1&#xff09;、 Set集合的特点 元素存储可以有序&#xff0c;可以无序&#xff08;要看选择的具体子类 HashSet 无序 LinkedHashSet&#xff08;有序&#xff09;,TreeSet&#xff08;排序&#xff09;&#xff09; 没有索引&#xff0c;不能通过索引…

学生成绩录入及查询(结构体)

学生成绩表中&#xff0c;一名学生的信息包含如下信息&#xff1a; 学号(11位)、姓名、数学成绩、英语成绩、程序设计成绩、物理成绩。 本题要求编写程序&#xff0c;录入N条学生的信息&#xff0c;并且按查询要求显示学生成绩等信息。 输入格式: 输入在第一行给出正整数N(N…

Java学习网站,哪个最靠谱?

简介 Java学习网站有很多&#xff0c;哪个最靠谱呢&#xff1f;本文对Java学习网站进行对比。 第1类&#xff1a;大型培训机构(黑马等) 典型机构 黑马、尚硅谷、动力节点、白马、千锋、达内。 优点 知名度高。教程齐全&#xff08;Java、前端、Python等都有&#xff09;省…

PiflowX组件-ReadFromUpsertKafka

ReadFromUpsertKafka组件 组件说明 upsert方式从Kafka topic中读取数据。 计算引擎 flink 有界性 Unbounded 组件分组 kafka 端口 Inport&#xff1a;默认端口 outport&#xff1a;默认端口 组件属性 名称展示名称默认值允许值是否必填描述例子kafka_hostKAFKA_HO…

AI看图识熊实战(一)

使用ONNX Runtime封装onnx模型并推理 进行这一步之前&#xff0c;请确保已正确安装配置了Visual Studio 2017 和 C#开发环境。 项目的代码也可以在这里找到&#xff0c;下面的步骤是带着大家从头到尾做一遍。 界面设计 创建Windows窗体应用(.NET Framework)项目&#xff0c…

c# 学习笔记 - 枚举

文章目录 1. 枚举1.1 枚举结构梳理1.2 枚举完整代码1.3 枚举知识点补充 2. 迭代两种命名空间接口3. yield语句 1. 枚举 1.1 枚举结构梳理 结构图   上图内容可能依旧不通俗易懂&#xff0c;这里使用最简明的话语告诉大家实现方式. foreach语句就是集合的遍历操作&#xff0c…

221.【2023年华为OD机试真题(C卷)】字符串变换最小字符串(贪心策略-JavaPythonC++JS实现)

🚀点击这里可直接跳转到本专栏,可查阅顶置最新的华为OD机试宝典~ 本专栏所有题目均包含优质解题思路,高质量解题代码(Java&Python&C++&JS分别实现),详细代码讲解,助你深入学习,深度掌握! 文章目录 一. 题目二.解题思路三.题解代码Python题解代码JAVA题解…

2024.1.3力扣每日一题——从链表中移除节点

2024.1.3 题目来源我的题解方法一 递归方法二 栈方法三 反转链表方法四 单调栈头插法 题目来源 力扣每日一题&#xff1b;题序&#xff1a;2487 我的题解 方法一 递归 当前节点对其右侧节点是否删除无影响&#xff0c;因此可以对其右侧节点进行递归移除。 若当前节点为空&am…

快速掌握Postman实现接口测试

快速掌握Postman实现接口测试 Postman简介 Postman是谷歌开发的一款网页调试和接口测试工具&#xff0c;能够发送任何类型的http请求&#xff0c;支持GET/PUT/POST/DELETE等方法。Postman非常简单易用&#xff0c;可以直接填写URL&#xff0c;header&#xff0c;body等就可以发…

Unity2D学习笔记 | 《勇士传说》教程 | (六)

目录 &#xff08;一&#xff09;存档点对象制作 &#xff08;二&#xff09;保存数据与加载数据 &#xff08;三&#xff09;存储数值与场景 &#xff08;四&#xff09;游戏结束画面制作 &#xff08;五&#xff09;序列化数据保存 &#xff08;一&#xff09;存档点对象…

Java多线程技术11——ThreadPoolExecutor类的使用2

1 isShutdown()方法 public boolean isShutdown()方法的作用是判断线程池是否已经关闭 public class Run1 {public static void main(String[] args) {Runnable runnable new Runnable() {Overridepublic void run() {try {System.out.println("开始: " Thread.c…

软件安装文档 | MinIO

# docker 下载镜像 docker pull minio/minio# 安装镜像docker run \ --name minio \ -p 19000:9000 \ -p 19090:9090 \ -d --restartalways \ -e "MINIO_ROOT_USERsuweijie" \ -e "MINIO_ROOT_PASSWORDSuweijie0217" \ -v /home/data:/data \ -v /home/c…

嵌入式培训机构四个月实训课程笔记(完整版)-Linux系统编程第三天-Linux进程练习题(物联技术666)

更多配套资料CSDN地址:点赞+关注,功德无量。更多配套资料,欢迎私信。 物联技术666_嵌入式C语言开发,嵌入式硬件,嵌入式培训笔记-CSDN博客物联技术666擅长嵌入式C语言开发,嵌入式硬件,嵌入式培训笔记,等方面的知识,物联技术666关注机器学习,arm开发,物联网,嵌入式硬件,单片机…

优化|PLSA理论与实践

PLSA又称为概率潜在语义分析&#xff0c;是一种利用概率生成模型对文本集合进行话题分析的无监督学习方法。该模型最大的特点是加入了主题这一隐变量&#xff0c;文本生成主题&#xff0c;主题生成单词&#xff0c;从而得到单词-文本共现矩阵。本文将对包含物理学、计算机科学、…