位置: IT常识 - 正文

React Hook - useEffecfa函数的使用细节详解

编辑:rootadmin
React Hook - useEffecfa函数的使用细节详解 文章目录useEffect的详细解析useEffecf基本使用清除副作用(Effect)使用多个useEffectuseEffect性能优化useEffect的详细解析useEffecf基本使用

推荐整理分享React Hook - useEffecfa函数的使用细节详解,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

书接上文, 上一篇文章我们讲解了State Hook, 我们已经可以通过这个hook在函数式组件中定义state

我们知道在类组件中是可以有生命周期函数的, 那么如何在函数组件中定义类似于生命周期这些函数呢?

Effect Hook 可以让你来完成一些类似于class中生命周期的功能;

事实上,类似于网络请求、手动更新DOM、一些事件的监听,都是React更新DOM的一些副作用(Side Effects);

所以对于完成这些功能的Hook被称之为 Effect Hook;

假如我们现在有一个需求:页面中的title总是显示counter的数字,分别使用class组件和Hook实现:

类组件实现

import React, { PureComponent } from 'react'export class App extends PureComponent { constructor() { super() this.state = { counter: 100 } } // 进入页面时, 标题显示counter componentDidMount() { document.title = this.state.counter } // 数据发生变化时, 让标题一起变化 componentDidUpdate() { document.title = this.state.counter } render() { const { counter } = this.state return ( <div> <h2>{counter}</h2> <button onClick={() => this.setState({counter: counter+1})}>+1</button> </div> ) }}export default App

函数组件加Hook的实现:

通过useEffect这个Hook,可以告诉React需要在渲染后执行某些操作;useEffect要求我们传入一个回调函数,在React执行完更新DOM操作之后(也就是组件被渲染完成后),就会回调这个函数;默认情况下,无论是第一次渲染之后,还是每次更新之后,都会执行这个回调函数; 一般情况下我们在该回调函数中都是编写副作用的操作(例如网络请求, 操作DOM, 事件监听)

因此需要注意的是, 有许多说法说useEffect就是用来模拟生命周期的, 其实并不是; useEffect可以做到模拟生命周期, 但是他主要的作用是用来执行副作用的

import React, { memo, useEffect, useState } from 'react'const App = memo(() => { const [counter, setCounter] = useState(200) // useEffect传入一个回调函数, 在页面渲染完成后自动执行 useEffect(() => { // 一般在该回调函数在编写副作用的代码(网络请求, 操作DOM, 事件监听) document.title = counter }) return ( <div> <h2>{counter}</h2> <button onClick={() => setCounter(counter+1)}>+1</button> </div> )})export default App清除副作用(Effect)

在class组件的编写过程中,某些副作用的代码,我们需要在componentWillUnmount中进行清除:

比如我们之前的事件总线或Redux中手动调用subscribe;

React Hook - useEffecfa函数的使用细节详解

都需要在componentWillUnmount有对应的取消订阅;

Effect Hook通过什么方式来模拟componentWillUnmount呢?

useEffect传入的回调函数A本身可以有一个返回值,这个返回值是另外一个回调函数B:

type EffectCallback = () => (void | (() => void | undefined));

为什么要在 effect 中返回一个函数?

这是 effect 可选的清除机制。每个 effect 都可以返回一个清除函数;

如此可以将添加和移除订阅的逻辑放在一起;

它们都属于 effect 的一部分;

React 何时清除 effect?

React 会在组件更新和卸载的时候执行清除操作, 将上一次的监听取消掉, 只留下当前的监听 ;

正如之前学到的,effect 在每次渲染的时候都会执行;

import React, { memo, useEffect } from 'react'const App = memo(() => { useEffect(() => { // 监听store数据发生改变 const unsubscribe = store.subscribe(() => { }) // 返回值是一个回调函数, 该回调函数在组件重新渲染或者要卸载时执行 return () => { // 取消监听操作 unsubscribe() } }) return ( <div> <h2>App</h2> </div> )})export default App使用多个useEffect

使用Hook的其中一个目的就是解决class中生命周期经常将很多的逻辑放在一起的问题:

比如网络请求、事件监听、手动修改DOM,这些往往都会放在componentDidMount中;

一个函数组件中可以使用多个Effect Hook,我们可以将逻辑分离到不同的useEffect中:

import React, { memo, useEffect } from 'react'const App = memo(() => { // 监听的useEffect useEffect(() => { console.log("监听的代码逻辑") return () => { console.log("取消的监听代码逻辑") } }) // 发送网络请求的useEffect useEffect(() => { console.log("网络请求的代码逻辑") }) // 操作DOM的useEffect useEffect(() => { console.log("操作DOM的代码逻辑") }) return ( <div> App </div> )})export default App

Hook允许我们按照代码的用途分离它们, 而不是像生命周期函数那样, 将很多逻辑放在一起:

React将按照 effect

本文链接地址:https://www.jiuchutong.com/zhishi/300856.html 转载请保留说明!

上一篇:vue导入处理Excel表格详解(导入vue.js)

下一篇:nmap命令 网络探测及端口扫描工具(nmap的命令)

  • 软文推广在网站推广中起着重要作用(软文推广去哪个网站好)

    软文推广在网站推广中起着重要作用(软文推广去哪个网站好)

  • 12306订票怎么查看卧铺床铺情况(12306订票怎么查看座位号)

    12306订票怎么查看卧铺床铺情况(12306订票怎么查看座位号)

  • 抖音能同时登录两个账号吗

    抖音能同时登录两个账号吗

  • 把好友删了再加回来他知道吗(把好友删了再加回来怎么解释)

    把好友删了再加回来他知道吗(把好友删了再加回来怎么解释)

  • 群文件删除失败(群文件无法删除)

    群文件删除失败(群文件无法删除)

  • 苹果11是英特尔基带吗(苹果11是英特尔芯片吗)

    苹果11是英特尔基带吗(苹果11是英特尔芯片吗)

  • oppo拼多多怎么卸载不了(OPPO拼多多怎么删除好友?)

    oppo拼多多怎么卸载不了(OPPO拼多多怎么删除好友?)

  • 微信退出后重新登录聊天记录(微信退出后重新登录聊天记录怎么恢复)

    微信退出后重新登录聊天记录(微信退出后重新登录聊天记录怎么恢复)

  • sim卡发送了一条文本信息什么意思(手机一直显示您的sim卡发送了一条)

    sim卡发送了一条文本信息什么意思(手机一直显示您的sim卡发送了一条)

  • 华为无线传声有什么用(华为手机无线传声怎么容易断开)

    华为无线传声有什么用(华为手机无线传声怎么容易断开)

  • 删了对方,对方的备注会变吗(删了对方对方还能收到转账吗)

    删了对方,对方的备注会变吗(删了对方对方还能收到转账吗)

  • 淘宝优先试用是免费的吗(淘宝优先试用是真的吗)

    淘宝优先试用是免费的吗(淘宝优先试用是真的吗)

  • 主机号码未显示是怎么回事(主机号码未显示是什么电活)

    主机号码未显示是怎么回事(主机号码未显示是什么电活)

  • 电脑升级系统后原有文件还存在吗(电脑升级系统后键盘不能用)

    电脑升级系统后原有文件还存在吗(电脑升级系统后键盘不能用)

  • 京东账号注销后,实名认证还在吗(京东账号注销后怎么申请恢复)

    京东账号注销后,实名认证还在吗(京东账号注销后怎么申请恢复)

  • 苹果手机最近通话记录怎么不显示了(苹果手机最近通话记录怎么设置延长)

    苹果手机最近通话记录怎么不显示了(苹果手机最近通话记录怎么设置延长)

  • 华为p30pro是什么处理器(华为p30pro是什么接口)

    华为p30pro是什么处理器(华为p30pro是什么接口)

  • 小米手环4出现月亮图案是什么意思(小米手环4出现请先绑定和监管是怎么回事)

    小米手环4出现月亮图案是什么意思(小米手环4出现请先绑定和监管是怎么回事)

  • 苹果就寝怎么删除(苹果就寝怎么删除不了)

    苹果就寝怎么删除(苹果就寝怎么删除不了)

  • 哔哩哔哩卡有什么用(哔哩哔哩卡有什么优惠)

    哔哩哔哩卡有什么用(哔哩哔哩卡有什么优惠)

  • airpods不用的时候怎么关(airpods不用的时候需要关机吗)

    airpods不用的时候怎么关(airpods不用的时候需要关机吗)

  • 如何做人脸识别(如何做人脸识别登录)

    如何做人脸识别(如何做人脸识别登录)

  • 安装win7系统的方法是什么?(安装win7系统的硬件要求)

    安装win7系统的方法是什么?(安装win7系统的硬件要求)

  • 基于vue-simple-uploader封装文件分片上传、秒传及断点续传的全局上传(基于网页的客服系统)

    基于vue-simple-uploader封装文件分片上传、秒传及断点续传的全局上传(基于网页的客服系统)

  • groupmod命令  更改群组属性(groupinfo命令)

    groupmod命令 更改群组属性(groupinfo命令)

  • websocket前后端数据实时更新(前端+后端)(websocket前端vue)

    websocket前后端数据实时更新(前端+后端)(websocket前端vue)

  • 实收资本印花税最新规定
  • 卖旧书侵权吗
  • 出口货物退税是指
  • 在途物资什么科目
  • 销货退回的税务处理
  • 土地增值税清算是什么意思
  • 制造费用属于资产类账户吗
  • 月末计算各种税费表格模版
  • 捐助建学校
  • 不动产证上宗地图名字错一个字
  • 运输发票的税率分类
  • 业务宣传费和广告费有什么区别
  • 会议费税前扣除标准2021
  • 取得赔偿款的发票可以抵扣吗
  • 员工误餐费的会计分录
  • 应付未付的款项怎么写凭证
  • 企业支付水电费属于什么费用
  • 1697508432
  • 2020工会经费退费
  • 开成品油发票要注意什么?
  • linux系统之间拷贝文件命令
  • PHP If Else(elsefi) 语句
  • 差旅费是否可以所得税前扣除
  • 医保和养老保险一样吗
  • 资产减值损失在哪个表
  • php 智能家居
  • 混合筹资的定义
  • 电子承兑兑现手续费
  • 联想thinkpad l380yoga
  • 贵的u盘和便宜的有什么区别
  • 认缴制下实收资本需要验资吗
  • linux搭建web服务器
  • 表单建模
  • php 微信公众号
  • uni-swiper-dot
  • 增值税注明的价款是含税还是不含税
  • thinkphp codeigniter
  • php ajax 实现
  • mysql查找重复项
  • 增值税抵扣要求一一对应
  • 民办幼儿园需要什么资质
  • 残疾人加计扣除工资按应发还是实发
  • 待摊费用和预提费用属于什么账户
  • 税务发票红字发票怎么开
  • 滴滴普通发票如何开
  • 实际发生坏账损失不影响应收账款
  • 不动产用于集体福利进项税额抵扣吗
  • 辞退福利为什么不计入产品成本
  • 十个提高情商的方法
  • 定期定额个体工商户怎么报税
  • 计提的坏账应该计入哪个科目
  • 企业固定资产可以不提折旧吗
  • 企业注销时实收资本清算时要作资产处置收益交所得税吗
  • 附加税减免需要转营业外收入吗
  • session几种存储方式
  • ubuntu常用的50个命令
  • upskill
  • windows10推送
  • linux操作系统启动
  • 备份linux命令
  • 华硕电脑升级win11
  • centos运行程序
  • win10周年版
  • qqlogin.exe是什么进程 qqlogin.exe应用程序错误解决办法
  • 开机需要两次
  • 解决安装后软件icon一圈白边问题
  • perl时间函数
  • 函数里面声明函数
  • android游戏开发 教程
  • android开源软件
  • 深入浅出讲解es63
  • 删除批处理命令
  • 最基本的实现进程是
  • javascriptj
  • jquery属性操作
  • [置顶]马粥街残酷史
  • android图库
  • 即征即退的留抵税额是否可以抵一般计税的税额
  • etc可以抵扣吗
  • 贵州社保在线年审官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设