关于useEffect的第二个参数解读

目录
  • useEffect的第二个参数
    • useEffect规则
    • 第二个参数的规则
    • 不同值的参数
    • 示例
  • useEffect使用技巧

useEffect的第二个参数

useEffect规则

  • 在每次render之后执行
  • 接收第二个参数来控制跳过执行,下次render后如果指定的值没有变化就不会执行
  • useEffect时在render之后浏览器已经渲染结束才执行

第二个参数的规则

  • 它是可选的
  • 类型是一个数组

不同值的参数

  • 不传参数
  • 空数组
  • 一个值的数组
  • 多个值的数组

示例

1. 没有第二个参数时,组件的初始话和更新都会执行

const [count, setCount] = useState(0)
useEffect(() => {
    console.log("useEffect:", count)
})

2. 空数组时,初始化调用一次之后不再执行,相当于componentDidMount

const [count, setCount] = useState(0)
useEffect(() => {
    console.log("useEffect:", count)
}, [])

3. 有一个值的数组时,该值有变化就执行

4. 有多个值的数组时,只要有一个值有变化就执行

const [count1, setCount1] = useState(0)
const [count2, setCount2] = useState(0)
useEffect(() => {
    console.log(count1, count2)
}, [count1, count2])

useEffect使用技巧

useEffect如果第二个参数的数组不为空,传了多个参数的情况下,使用总结。

如果第二个传了多个参数,如何查看是那个参数发生了变化呢?请看代码:

// 在一个正常的Hooks函数中,有如下代码,此代码实现的原理就是通过useRef来达到缓存的目的
  const [a, setA] = useState();
  const [b, setB] = useState();
  const [c, setC] = useState();
  const myRef = useRef({a, b, c});
  useEffect(() => {
    const { a: prevA, b: prevB, c: prevC } = myRef.current;
    if (prevA !== a) {
      // 证明a发生了变化
    }
    if (prevB !== b) {
      // 证明b发生了变化
    }
    if (prevC !== c) {
      // 证明c发生了变化
    }
  }, [a, b, c])

有时使用useEffect会使组件一直处于不停的刷新,这个是为什么?

看如下代码,会使组件一直不停的刷新:

  const [a, setA] = useState<number[]>([]);

  useEffect(() => {
    setA([11])
  }, [a]);

而且此时此刻控制台也抛出了错误,如下图:

Warning: Maximum update depth exceeded. This can happen when a component calls setState inside useEffect, but useEffect either doesn't have a dependency array, or one of the dependencies changes on every render.
    at Home (http://localhost:8000/static/umi.js:93407:73)
    at Route
    at Switch
    at Router (http://localhost:8000/static/umi.js:86181:30)
    at RouterComponent (http://localhost:8000/static/umi.js:84374:23)
    at Provider (http://localhost:8000/static/umi.js:73004:20)
    at _DvaContainer (http://localhost:8000/static/umi.js:90776:5)
    at http://localhost:8000/static/umi.js:91243:24
    at ./src/.umi/plugin-model/Provider.tsx.__webpack_exports__.default (http://localhost:8000/static/umi.js:91706:23)

为何会一直刷新呢?

因为传给useEffect的第二个参数为引用类型,因为两个引用类型在进行比较的时候永远都是不相等的,以数组为例,声明一个数组就是从Array类上实例化出来了一个新对象,然后JS引擎会为这个对象分配内存空间,所以不同的对象,就会有不同的内存空间,所以两个引用类型的比较永远都是不相等的;例如:

console.log([] === []); //false,此时注意一下,两个是不相等的

有了以上的了解,在使用useEffect的时候就应该注意两点:

1. 第二个参数对应的数组中,尽量避免使用引用类型(此时可以在第一个参数也就是执行的副作用函数中调用setState相关的代码)。

2.如果第二个参数中用了引用类型,就应该在第一个参数也就是执行的副作用函数中不要用setState相关的代码,要不然会使得组件陷入到死循环中,报上面的错误。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • React useEffect的理解与使用

    React16.8新增的useEffec这个hook函数就是处理副作用的. 所谓的"副作用",举个通俗一点的例子,假如感冒了本来吃点药就没事了,但是吃了药发现身体过敏了,而这个"过敏"就是副作用. 放到React中,本来只是想渲染DOM展示到页面上,但除了DOM之外还有数据,而这些数据必须从外部的数据源中获取,这个"获取外部数据源"的过程就是副作用. useEffect怎么用可以参考官网给出的例子,这里主要针对使用useEffect过程中遇到的问

  • React-hooks中的useEffect使用步骤

    目录 1.理解函数副作用 什么是副作用? 常见的副作用 2.基础使用 使用步骤 示例代码 3.依赖项控制 useEffect 永远是在 DOM渲染完成之后执行 1.理解函数副作用 什么是副作用? 对于React组件来说,主作用是根据数据(state/props)渲染UI,除此之外都是副作用(比如手动修改DOM.发送ajax请求). 常见的副作用 数据请求(发送ajax) 手动修改 DOM localstorage操作 useEffect 函数的作用就是为react函数组件提供副作用 2.基础使用

  • React useEffect异步操作常见问题小结

    目录 三个常见的问题: 一.react hooks发异步请求 二.如何在组件加载的时候发起异步任务 三.如果在响应回来之前组件被销毁了会怎样? 四.如何在组件交互时发起异步任务 为什么两种写法会有差异呢? 五.其他陷阱 总结 useEffect 和异步任务搭配使用的时候会遇到的一些坑总结. 三个常见的问题: 1.如何在组件加载的时候发起异步任务 2.如何在组件交互的时候发起异步任务 3.其他陷阱 一.react hooks发异步请求 1.使用useEffect发起异步任务,第二个参数使用空数组可

  • 关于useEffect的第二个参数解读

    目录 useEffect的第二个参数 useEffect规则 第二个参数的规则 不同值的参数 示例 useEffect使用技巧 useEffect的第二个参数 useEffect规则 在每次render之后执行 接收第二个参数来控制跳过执行,下次render后如果指定的值没有变化就不会执行 useEffect时在render之后浏览器已经渲染结束才执行 第二个参数的规则 它是可选的 类型是一个数组 不同值的参数 不传参数 空数组 一个值的数组 多个值的数组 示例 1. 没有第二个参数时,组件的初

  • jQuery()方法的第二个参数详解

    关于jQuery()方法的第二个参数,有下面这几种用法: 1.jQuery(selector, [context]) 这种用法,相当于 $(context).find(selector) 或者 context.find(selector) 2.jQuery(html, [ownerDocument]) 文档对ownerDocument的解释是:"创建DOM元素所在的文档" 也就是说,如果你要编写挎document的脚本,比如iframe或者用window.open开一个新窗口,可能会用

  • Javascript中字符串replace方法的第二个参数探究

    前言 replace第一个参数一般放置的是正则表达式,用来匹配想要替换的文本:第二个参数一般我们放入的是字符串,用来替换掉正则匹配到的文本. 其实replace远比上面说的要强大的多,它的内部已经封装的很完善了,远不是我们想象的那么简单,下面我们就来详细聊聊replace的第二个参数. 实例介绍 现在要实现一个功能,把HTML中的字符实体转换成它们所对应的字符,比如:"<"转换成对对应字符为:"<". 下面我们来看看代码实现: String.protot

  • jQuery函数的第二个参数获取指定上下文中的DOM元素

    jQuery函数的第二个参数可以指定DOM元素的搜索范围. 第二个参数可分为以下类型 DOM reference jQuery wrapper document 代码示例 复制代码 代码如下: <!DOCTYPE html> <html> <body> <form> <input name="" type="checkbox"/> <input name="" type="

  • javascript replace()第二个参数为函数时的参数用法

    javascript的replace()第二个参数为函数时的参数: replace()函数具有替换功能,它可以具有两个参数,第一个参数可以是要被替换的字符串或者匹配要被替换字符串的正则表达式,第二个参数可以是替换文本或者一个函数,下面看一下关于replace()函数的几个代码实例. 代码实例: 实例一: <script> var str="I love jb51 and you?"; console.log(str.replace("jb","

  • php define的第二个参数使用方法

    看手册说define定义的常量只允许:仅允许标量和 null.标量的类型是 integer, float,string 或者 boolean. 也能够定义常量值的类型为 resource ,但并不推荐这么做,可能会导致未知状况的发生.今天阅读php源码,发现define的第二个参数其实也可以是一个对象.先贴一段示例: 复制代码 代码如下: class A {    public function __toString() {        return 'bar';    }} $a = new

  • python目标检测数据增强的代码参数解读及应用

    目录 数据增强做了什么 目标检测中的图像增强 全部代码 数据增强做了什么 数据增强是非常重要的提高目标检测算法鲁棒性的手段,学习一下对身体有好处! 数据增强其实就是让图片变得更加多样.比如说原图是一个电脑 如果不使用数据增强的话这个电脑就只是一个电脑,每次训练的电脑都是这样的样子的,但是我们实际生活中电脑是多样的. 因此我们可以通过改变亮度,图像扭曲等方式使得图像变得更加多种多样,如下图所示,尽管亮度,形态发生了细微改变,但本质上,这些东西都依然是电脑. 改变后的图片放入神经网络进行训练可以提高

  • NetWorkX使用方法及nx.draw()相关参数解读

    目录 代码 networkx–nx.draw()参数 运行样式 运用布局 添加文本 总结 networkx在02年5月产生,是用python语言编写的软件包,便于用户对复杂网络进行创建.操作和学习. 利用networkx可以以标准化和非标准化的数据格式存储网络.生成多种随机网络和经典网络.分析网络结构.建立网络模型.设计新的网络算法.进行网络绘制等. 官方文档:https://www.osgeo.cn/networkx/reference/introduction.html 代码 首先导入包 i

  • react中使用useEffect及踩坑记录

    目录 使用useEffect及踩坑记录 useEffect 介绍 useEffect常见跳坑 hooks中useEffect()使用总结 常见使用 useEffect() 的第二个参数说明 useEffect() 第一个函数参数的返回值 useEffect() 的注意点 使用useEffect及踩坑记录 useEffect 介绍 useEffect时reactHook中最重要,最常用的hook之一. useEffect相当于react中的什么生命周期呢? 这个问题在react官网中有过介绍,在使

  • react中的watch监视属性-useEffect介绍

    目录 react的watch监视属性-useEffect useEffect使用指南 最基本的使用 响应更新 如何处理Loading和Error 处理表单 自定义hooks 使用useReducer整合逻辑 取消数据请求 react的watch监视属性-useEffect 在vue中可以使用watch属性,去监视一个值,当这个值进行变化的时候就去执行一些操作.在react是没有这个属性的,但是它也一样可以达到相同的效果,那么接下来看看它是怎么实现的呢? 在react中实现监听效果有一个比较简单的

随机推荐