【React】useEffect使用详解

这篇具有很好参考价值的文章主要介绍了【React】useEffect使用详解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

useEffect 介绍

如果你熟悉 React class 的生命周期函数,你可以把 useEffect Hook 看做
componentDidMount,componentDidUpdate 和 componentWillUnmount 这三个函数的组合。

  • componentDidMount 组件挂载
  • componentDidUpdate 组件更新
  • componentWillUnmount 组件将要摧毁

使用方法
情况一:

  • useEffect需要传递两个参数,第一个参数是逻辑处理函数,第二个参数是一个数组
    代码如下:
useEffect(() => {
/** 执行逻辑 */
},[])

情况二:

  • 第二个参数存放变量,当数组存放变量发生改变时,第一个参数,逻辑处理函数将会被执行
  • 第二个参数可以不传,不会报错,但浏览器会无限循环执行逻辑处理函数。
    代码如下:
useEffect(() => {
/** 执行逻辑 */
})

情况三:

  • 第二个参数如果只传一个空数组,逻辑处理函数里面的逻辑只会在组件挂载时执行一次 ,等价于 componentDidMount
    代码如下:
useEffect(() => {
/** 执行逻辑 */
},[])

情况四:

  • 第二个参数如果不为空数组,依赖指定参数触发使用
  • 逻辑处理函数会在组件挂载时执行一次和(a或者b变量在栈中的值发生改变时执行一次) 这是不是相当于componentDidMount 和componentDidUpdate 的结合
const [a, setA] = useState(1);
const [b, setB] = useState(2);
useEffect(() => {
/** 执行逻辑 */
},[a,b])

情况五:

  • useEffect第一个参数可以返回一个回调函数,这个回调函数将会在组件被摧毁之前和再一次触发更新时,将之前的副作用清除掉。这就相当于componentWillUnmount。
  • useEffect去除副作用。我们可能会在组件即将被挂载的时候创建一些不断循环的订阅(计时器,或者递归循环)。在组件被摧毁之前,或者依赖数组的元素更新后,应该将这些订阅也给摧毁掉。
    比如以下的情况(没有去除计时器,增大不必要的开销和代码风险)
const [time, setTime] = useState(0)

useEffect(() => {
	const InterVal = setInterval(() => {
		setTime(time + 1)
	},1000)
},[])

处理在组件被摧毁前去除计时器

const [time, setTime] = useState(0)

useEffect(() => {
	const InterVal = setInterval(() => {
		setTime(time + 1)
	},1000)
	return () => {
   		clearInterval(InterVal )
   	}
},[])

特殊情况处理

useEffect监测不到依赖数组元素的变化。

只有一种可能,依赖数组元素的地址的值根本就没变,
原因:因为changeA没有真正的改变a在栈中的值(地址的值),只是改变了a在堆中的值。
useEffect监测不到堆中值得变化,所有引用类型数据都应该注意这一点。文章来源地址https://www.toymoban.com/news/detail-436129.html

代码示例:
const [a, setA] = useState({
b: 'dx',
c: '18',
})

const changeA = () => {
	setA((old) => {
	old.b = 'yx'
	return old
	})
}

useEffect(() => {
/** 当组件挂载时执行一次changeA */
changeA ()
},[])

/**当changeA执行却没有打印 a*/
useEffect(() => {
/** 执行逻辑 */
console.log(a)
},[a])
解决的办法
const [a, setA] = useState({
b: 'dx',
c: '18',
})

const changeA = () => {
	setA((old) => {
	const newA = {...old}
	newA .b = 'yx'
	return newA 
	})
}

useEffect(() => {
/** 当组件挂载时执行一次changeA */
changeA ()
},[])

/**当changeA执行打印  {b:'yx',c:'18'}  */
useEffect(() => {
/** 执行逻辑 */
console.log(a)
},[a])

到了这里,关于【React】useEffect使用详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • useEffect使用详解

    useEffect 是React中的一个钩子函数,用于处理副作用操作。副作用是指在组件渲染过程中,可能会对外部环境产生影响的操作,比如数据获取、订阅事件、操作DOM等。 useEffect 接受两个参数:一个是副作用函数,另一个是依赖数组。 副作用函数会在组件渲染时执行,并且在每次

    2024年02月11日
    浏览(25)
  • React的hooks---useEffect

    在函数组件主体内(React 渲染阶段)改变 DOM、添加订阅、设置定时器、记录日志以及执行其他包含副作用的操作都是不被允许的,因为这可能会产生莫名其妙的 bug 并破坏 UI 的一致性 useEffect Hook 的使用则是用于完成此类副作用操作。 useEffect 接收一个包含命令式、且可能有副

    2024年02月15日
    浏览(29)
  • React Hooks 源码解析:useEffect

    React Hooks 源码解析(4):useEffect React 源码版本: v16.11.0 源码注释笔记:airingursb/react 1.1 为什么要有 useEffect 我们在前文中说到 React Hooks 使得 Functional Component 拥有 Class Component 的特性,其主要动机包括: 在组件之间复用状态逻辑很难 复杂组件变得难以理解 难以理解的 class 对

    2024年01月21日
    浏览(31)
  • react的严格模式 和 解决react useEffect执行两次

    这个问题,主要是刚接触react的时候发的问题,当时也没总结。现在回过头来再总结一次!!! 能发现这个问题的👨‍🎓,一定是一名细心并且有一颗求知的❤️。 因为我当时接触React的时候就是这样的想法。 为什么会触发两次?按照正常的声明周期应该执行一次的!!!

    2024年02月04日
    浏览(30)
  • 【React 】useLayoutEffect 和 useEffect的区别

    useLayoutEffect 和 useEffect 是React中常用的两个Hook,它们的主要区别在于触发时机。 useEffect 会在渲染完成后异步执行,不会阻塞浏览器的绘制操作。它适用于需要在组件渲染后执行副作用的情况,例如数据的获取、订阅事件等。它不会阻止屏幕更新,因此可能会导致渲染的一次

    2024年02月09日
    浏览(35)
  • 通过chatgpt 学习React的useEffect

    定义: useEffect 是 React 中的一个 Hook,它用于处理函数组件中的副作用操作。副作用操作可以包括数据获取、订阅事件、定时器等。 useEffect 接受两个参数:第一个参数是一个回调函数,用于执行副作用操作;第二个参数是一个数组,用于指定依赖项,只有当依赖项发生变化时

    2024年02月10日
    浏览(28)
  • React18的useEffect会执行两次

    前段时间在本地启了一个 React Demo 项目,在编码的过程中遇到一个很奇怪的“Bug”。 其中简化版的代码如下所示。 我是万万没想到,就这样几行简单的代码竟然会触发一个“Bug”。 此“Bug”的表现为: 在 Chrome 控制台里发现 “Hello world!” 被打印了 “两次”。 刷新之后依然

    2024年02月04日
    浏览(35)
  • React hooks之useEffect、useMemo优化技巧

    useEffect使用JSON.stringfy进行过滤,避免重复执行 将数组直接放入依赖数组可能不会按预期工作,因为数组比较是基于引用而不是内容。也就是说,如果数组引用没有变,即使数组内容发生了变化,副作用也不会重新运行。或者数组内饿哦那个没有改变但是引用却发生变化时,

    2024年02月12日
    浏览(37)
  • 理解 React 中的 useEffect、useMemo 与 useCallback

    先理解 useEffect 有助于学习 useMemo 和 useCallback。因为 useMemo 和 useCallback 的实现实际上都是基于 useEffect 的。 useEffect 是 React 中的一个很重要的 Hook,用于执行副作用操作。什么是副作用?简单来说,就是那些会改变函数外部变量或有外部可观察影响的操作。useEffect 允许你在函

    2024年02月03日
    浏览(32)
  • react18中,useState 和 useEffect有什么区别

    useState 目的:useState用于在函数组件中添加状态。之前,只有类组件才能有自己的状态,但useState钩子使得函数组件也能够利用React的状态特性。 使用场景:当你需要在组件中存储、读取或更新一些数据时使用。例如,控制输入框的内容、切换按钮的状态等。 工作原理:useS

    2024年02月19日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包