位置: 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的命令)

  • 水星MAC1200R怎么设置访客网络(水星mac1200r怎么判断是千兆)

    水星MAC1200R怎么设置访客网络(水星mac1200r怎么判断是千兆)

  • airpods有麦克风吗(airpods有麦克风功能吗)

    airpods有麦克风吗(airpods有麦克风功能吗)

  • 华为语言设置成英文如何改过来(华为设置语言界面)

    华为语言设置成英文如何改过来(华为设置语言界面)

  • iphone12在哪里设置自拍镜像(iphone12在哪里设置apple pay)

    iphone12在哪里设置自拍镜像(iphone12在哪里设置apple pay)

  • 蓝牙耳机有一只连不上灯也不闪(蓝牙耳机有一只没声音怎么回事)

    蓝牙耳机有一只连不上灯也不闪(蓝牙耳机有一只没声音怎么回事)

  • 微信号四年没登会注销吗(微信号四年没登录怎么办)

    微信号四年没登会注销吗(微信号四年没登录怎么办)

  • 网易云主页被访问有记录吗(网易云主页访客在哪里看)

    网易云主页被访问有记录吗(网易云主页访客在哪里看)

  • 华为nova7跟nova7se的区别(华为nova7跟nova7se外观有什么区别)

    华为nova7跟nova7se的区别(华为nova7跟nova7se外观有什么区别)

  • 抖音公会勿扰啥意思(公会勿扰有什么好处)

    抖音公会勿扰啥意思(公会勿扰有什么好处)

  • 苹果手机微信总是闪退怎么回事(苹果手机微信总是卡住不动)

    苹果手机微信总是闪退怎么回事(苹果手机微信总是卡住不动)

  • qq被屏蔽了会有提示吗(qq被屏蔽后还能看到对方动态吗)

    qq被屏蔽了会有提示吗(qq被屏蔽后还能看到对方动态吗)

  • 收音机st和loc什么意思(收音机st loc是什么)

    收音机st和loc什么意思(收音机st loc是什么)

  • soul举报对方看得到吗(soul举报成功对方能收到消息不)

    soul举报对方看得到吗(soul举报成功对方能收到消息不)

  • 怎样卸载手机上的软件(怎样卸载手机上已下载的软件)

    怎样卸载手机上的软件(怎样卸载手机上已下载的软件)

  • 苹果5有没有录屏功能(苹果5有没有录制屏幕)

    苹果5有没有录屏功能(苹果5有没有录制屏幕)

  • vivo手机反向充电怎么打开(vivo手机反向充电功能)

    vivo手机反向充电怎么打开(vivo手机反向充电功能)

  • 微信漂流瓶啥下线了(2021微信漂流瓶)

    微信漂流瓶啥下线了(2021微信漂流瓶)

  • 在Windows系统中怎样建立TXT记事本?(在windows 10中)

    在Windows系统中怎样建立TXT记事本?(在windows 10中)

  • Apple ID怎么解绑银行卡 Apple ID解除绑定银行卡教程(apple ID怎么解绑设备)

    Apple ID怎么解绑银行卡 Apple ID解除绑定银行卡教程(apple ID怎么解绑设备)

  • 金钱树的养殖方法和注意事项(金钱树的养殖方法和浇水方式)

    金钱树的养殖方法和注意事项(金钱树的养殖方法和浇水方式)

  • 微信小程序入门教程 --(保姆级)(微信小程序入门指南)

    微信小程序入门教程 --(保姆级)(微信小程序入门指南)

  • php中Composer的按需加载(php composer 常用库)

    php中Composer的按需加载(php composer 常用库)

  • 自然人税收管理系统残疾人申报
  • 企业所得税广告费30%扣除
  • 资源税的计税依据为应税产品的开采量
  • 广告公司与广告公司合作的协议
  • 报废的机器设备怎么处理
  • 有形动产租赁属于营改增吗
  • 个人银行账户怎么填写
  • 利润表盈利结构分析
  • 应纳税额减征额包括哪些内容
  • 中小企业税务管理存在的问题
  • 复合肥生产企业排名
  • 以银行存款支付水电费
  • 购买原材料产生的运输费计入什么科目
  • 未分配利润可以转盈余公积吗
  • 预收电费怎么做会计分录
  • 增值税只有销项没有进项怎么做账
  • 发票边上的虚线是什么
  • 为什么非征期不允许汇总上传
  • 销售商品货款已预收
  • 土地使用税每个月都要计提吗
  • 合并报表利润表是当期还是累计
  • 增值税各科目账务处理
  • 财政拨款税务处理方法
  • 联通官网测网速
  • 财务报表未分配利润为负数
  • 调增应纳税所得额季度申报表怎么填
  • 资产负债表期初和期末指的是什么
  • 土地价款扣除会计分录
  • 辅助生产车间照明用电计入哪个科目
  • 备注栏需要写内容嘛
  • 公司自建办公楼
  • 在linux中使用什么命令可以动态查看文件内容
  • windows优化设置
  • 二手车 交易税费
  • 个人独资企业和合伙企业的区别
  • 资产减值会计处理对利润的影响
  • 购买电脑固定资产怎么记账
  • apache 反射工具类
  • 会计审核费用报销单的职责
  • wordpress页面设置
  • 转账不同银行同城转账手续费多少
  • 股东之间股权转让需要股东会决议吗
  • 外贸企业出口退税申报流程
  • 装修公司开的劳务发票
  • 认缴出资和注册资本
  • 结转成本相关内容有哪些
  • 用支票偿还货款
  • 固定资产折旧准备属于什么科目
  • 固定资产低于净值出售会计处理
  • 没有发票意味着什么
  • 账上的进项税额比申报多了怎么调账
  • 企业取得的财政拨款
  • 汇算清缴后收到退回的所得税
  • 游戏公司的主营业务成本
  • 对公账户进出账常识
  • 营改增人力资源服务
  • 发票邮寄到家
  • 生产性生物资产折旧计入什么科目
  • 如何判断企业实际控制人
  • 短期薪酬主要包括
  • win7任务管理器快捷键ctrl+alt+
  • windows xp 任务栏在右边
  • SMax4PNP.exe - SMax4PNP是什么进程
  • puppset
  • linux wc命令详解
  • WIN10补丁无法卸载
  • linux操作系统内核
  • centos打包文件
  • xcopy /s /e
  • js复制数组的方法
  • python中怎么取整数的某位数
  • js判断用户输入密码
  • 轮廓理论
  • jquery鼠标点击
  • android退出功能
  • python 循环太慢
  • 北京市社会团体
  • 海口市地税局高峰简历
  • 广西税务登记查询网站
  • 重庆市大足区迪涛中学那几个是尖子班
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设