IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> react简单入门--常用hook中useEffect使用 -> 正文阅读

[JavaScript知识库]react简单入门--常用hook中useEffect使用

前言:
在react中创建class组件时,我们能够很容易地用特定的方法,来判别这个组件在什么生命周期里面处理什么逻辑,比如说,在componentDidMountcomponentDidUpdate中我们可能需要发一些请求,或者做一些初始化的操作,又或者在componentWillUnmount 我们有可能做一些清楚订阅的操作;但是在函数组件中,你要知道这个组件现在处在那个生命周期,却比较麻烦,甚至有点无从下手,这时候我们就可以使用hook中的useEffect()

1、导入:

这个和useState一样,无需从第三方包导入,直接从react中导入即可在这里插入图片描述

2、使用:

  • 场景一:在组件挂载时或者更新时获取dom元素

直接看代码吧在这里插入图片描述
页面效果:
在这里插入图片描述
也能过发现这个打印也确实是来自第74和77行的,也确实发现只要我给useEffect()中传入一个函数,在这个函数中是可以获取到dom元素的,这个效果也确实类似class组件中的componentDidMountcomponentDidUpdate。其实用class组件,有时候你不仅要在组件挂载时做一个操作,而在组件更新时也还要做同一个操作,回过头来,而useEffect,其实都帮你做了,你甚至可以把它想象成把componentDidMountcomponentDidUpdate结合起来了。

  • 场景二:在组件挂载时订阅或者创建定时器,在组件卸载时清除订阅或定时器id

为了实现该场景,我们又增加一个函数组件user,并把useEffect移入到user组件中去,其代码如下:

Home组件:
在这里插入图片描述

User组件:
在这里插入图片描述

页面效果:
请添加图片描述
根据测试,我们发现在user组件一开始时是会执行useEffect中第一个函数的,在我们user组件卸载时就会执行useEffect函数中return出来的函数,这其实就是useEffect的初衷,它不再像class组件,将componentDidMount()componentWillUnmount ()componentDidUpdate()等生命周期函数都分别列出来,还是合在了一起,更加方便简洁。

  • 场景三:上面的场景都是只有组件发生了变化就会触发effect,但是有时候我希望是某些条件满足了才会更新组件

先看代码:

home组件

在这里插入图片描述

user组件:
在这里插入图片描述
与场景二相比,发生的变化,我用红线或者红框标记出来了,最重要的改变就是我为user组件中的uaeEffect函数传了第二个参数,现在我们来看效果:(加第二个参数
请添加图片描述
观察发现,我点击按钮之后,这个user组件并没有再次调用effect了,那我们再把user组件的useEffect函数的第二个参数去掉再看看效果:(不加第二个参数
请添加图片描述
观察发现,这useEffect函数的第二个参数其实就是来控制该组件是不是需要更新,当然这个方法来满足你的需求的话,你需要注意一定要确保数组中包含了所有外部作用域中会发生变化且在 effect 中使用的变量,否则你的代码会引用到先前渲染中的旧变量。至于详情,可以看看官网中如何处理函数 以及数组频繁变化时的措施 的内容。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-18 15:53:03  更:2021-12-18 15:54:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 10:04:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码