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

  • 支付宝登录方式有几种(支付官方网站注册入口)

    支付宝登录方式有几种(支付官方网站注册入口)

  • 华为手机取消拦截在哪里设置(华为手机怎么把拦截提示关掉)

    华为手机取消拦截在哪里设置(华为手机怎么把拦截提示关掉)

  • 小度为什么开不了机(小度为什么开不开机)

    小度为什么开不了机(小度为什么开不开机)

  • iphone11pro续航时间(iphone11pro 续航)

    iphone11pro续航时间(iphone11pro 续航)

  • 手机qq怎么开启情侣空间(手机QQ怎么开启简洁模式)

    手机qq怎么开启情侣空间(手机QQ怎么开启简洁模式)

  • autoit error是什么意思(autoit error line0)

    autoit error是什么意思(autoit error line0)

  • 本地文件移动失败什么原因(本地文件损坏怎么办)

    本地文件移动失败什么原因(本地文件损坏怎么办)

  • 如何查看手机关机记录(如何查看手机关机期间打来的电话)

    如何查看手机关机记录(如何查看手机关机期间打来的电话)

  • 小爱音箱怎么关机重启(小爱音箱怎么关联qq音乐)

    小爱音箱怎么关机重启(小爱音箱怎么关联qq音乐)

  • 手机卡停用还会扣费吗(手机卡停用还会记录行程吗)

    手机卡停用还会扣费吗(手机卡停用还会记录行程吗)

  • 怎样在目录添加目录(怎么样在目录中添加自己想要的内容)

    怎样在目录添加目录(怎么样在目录中添加自己想要的内容)

  • 抖音里面的音浪怎么算(抖音里面的音浪是什么意思)

    抖音里面的音浪怎么算(抖音里面的音浪是什么意思)

  • 拼多多怎么使用复活卡(拼多多怎么使用亲属卡)

    拼多多怎么使用复活卡(拼多多怎么使用亲属卡)

  • qq自定义个性名片透明(qq自定义个性名片怎么设置)

    qq自定义个性名片透明(qq自定义个性名片怎么设置)

  • 画图的窗口几部分(画图窗口中都包括什么)

    画图的窗口几部分(画图窗口中都包括什么)

  • 微信重新登录聊天记录还有吗(微信重新登录聊天记录还在吗)

    微信重新登录聊天记录还有吗(微信重新登录聊天记录还在吗)

  • vivo耳机模式在哪里调(vivi手机耳机模式)

    vivo耳机模式在哪里调(vivi手机耳机模式)

  • 快手怎么特别关注主播(快手怎么特别关注和取消)

    快手怎么特别关注主播(快手怎么特别关注和取消)

  • 酷狗vip可以2人一起用吗(酷狗vip可以2人应该怎么登陆)

    酷狗vip可以2人一起用吗(酷狗vip可以2人应该怎么登陆)

  • id在哪里看(企业微信id在哪里看)

    id在哪里看(企业微信id在哪里看)

  • 在系统内存中设置磁盘缓冲区的主要目的是(系统内存中设置磁盘缓存的目的)

    在系统内存中设置磁盘缓冲区的主要目的是(系统内存中设置磁盘缓存的目的)

  • 抖音不互相关注能聊天吗(抖音不互相关注能发几条)

    抖音不互相关注能聊天吗(抖音不互相关注能发几条)

  • 手机吊绳怎么绑(手机吊绳怎么绑视频教程)

    手机吊绳怎么绑(手机吊绳怎么绑视频教程)

  • 【Vue3】如何创建Vue3项目及组合式API(创建vue3项目的步骤)

    【Vue3】如何创建Vue3项目及组合式API(创建vue3项目的步骤)

  • 铜川缴纳房屋契税怎么算
  • 账账核对的基本内容
  • 差额征税扣除额是什么意思
  • 企业申报表有异常期间可以更换财务负责人吗
  • 研发投入和研发支出的关系
  • 留抵进项税额
  • 股东溢价转让股份交易市场会计分录
  • 施工企业所得税税率是多少
  • 零申报企业年报资产总额怎么填
  • 公司过桥贷款怎么贷
  • 出售未完成折旧固定资产进项税转出
  • 红字通知单进项税额转出
  • 营业执照印花税税率
  • 物业管理行业税点
  • 自来水费缴纳后多久来水
  • 土地的增值税进项能否抵扣
  • 企业所得税视同销售的捐赠扣除
  • 开票税额与申报税额差一分账务怎么处理
  • 月销售额小于10万的一般纳税人减免
  • 企业偷税行为
  • 存货跌价准备可以转回吗?
  • iphone6s怎么开启开发者选项
  • 华为p50e手机价格及参数
  • php如何实现多进程
  • 计提长期待摊费用的会计分录
  • 查补以前年度增值税怎么申报
  • scrfs.exe - scrfs是什么进程 有什么用
  • 深入理解php内核
  • window10为什么右键就卡住
  • 讲解如何使用
  • 短期投资取得的收益
  • 小规模纳税人查询
  • 购入固定资产的会计处理
  • 跨境电商需要缴纳哪些税种
  • 二手房买卖要交契税吗
  • 采购预算测算依据
  • 给员工报销
  • trainer 平替
  • css3两种调整背景图片大小的方式
  • php 用户
  • 出口商品没有发票可以入收入吗
  • 公司出售固定资产的账务处理
  • 企业所得税会计利润总额计算公式
  • 交易性金融资产属于流动资产
  • 行程单入账多久钱能到账
  • 税务师报名条件和要求
  • 营改增试点纳税人提供技术转让
  • 小企业附加税减免政策
  • 所得税季度申报弥补以前年度亏损
  • 公众号注册验证退款
  • 小规模纳税人利润如何缴税
  • 差旅费可以加计吗
  • 单独计价作为固定资产入账的土地为什么不计提折旧
  • 废品损失的计算方法及废品损失的范围
  • mysql一闪而退
  • linux给root权限
  • win8无线网络连接不上
  • win7系统笔记本怎么连接wifi
  • inc是什么软件
  • 提示无法启动打印作业
  • mac命令行终端快捷键
  • centos新加硬盘
  • windows10不能在任务栏进行的操作
  • windows7 sp1升级包
  • win7电脑关机后自动开机怎么回事
  • python挑战
  • python让用户选择
  • qt opengl obj
  • firefox浏览器标识ua
  • python的导入
  • Node.js中的全局变量有哪些
  • js定义json对象
  • shell 非
  • js table
  • python 观察者
  • python讲解
  • 国家税务总局增值税发票查验平台网址
  • 江西省税务局官网查询系统
  • 河北省十大杰出五四青年
  • 烟叶税属于中央税还是地方税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设