前端学习笔记202307学习笔记第五十七天-模拟面试笔记react-useEffect和useLayontEffect区别

useEffect和useLayoutEffect都是ReactHooks,用于处理副作用。它们都在组件渲染后执行,但useLayoutEffect在DOM更新后立即执行,确保对DOM的操作在渲染后立即生效,而useEffect则在渲染周期的后期执行,允许浏览器进行批量更新。不指定依赖列表时,两者会在每次渲染时运行。
摘要由CSDN通过智能技术生成

react-useEffect和useLayontEffect区别

useEffect和uselayoutEffect都是副作用hooks,两则非常相似,同样都接收两个参数:

(1)第一个参数为函数,第二个参数为依赖列表,只有依赖更新时才会执行函数;返回一个函数,当页面刷新的或销毁的时候执行return后的代码;

(2)如果不接受第二个参数,那么在第一次渲染完成之后和每次更新渲染页面的时候,都会调用useEffect的回调函数;

useEffect和 useLayout的主要区别就是他们的执行时机不同,在浏览器中js线程与渲染线程是互斥的,当js线程执行时,渲染线程呈挂起状态,只有当js线程空闲时渲染线程才会执行,将生成的 dom绘制。useLayoutEffect在js线程执行完毕即dom更新之后立即执行,而useEffect是在渲染结束后才执行,也就是说 useLayoutEffect比 useEffect先执行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值