当前位置: 首页 > news >正文

react中useEffect和useLayoutEffect的区别

布局上

  • useEffect在浏览器渲染完成后执行
  • useLayoutEffect在DOM更新后执行

特点

  • useLayoutEffect 总是比 useEffect 先执行;useLayoutEffect与componentDidMount、componentDidUpdate调用时机相同,都是在DOM更新后,页面渲染前调用;useEffect在页面渲染后调用
  • 使用 useLayoutEffect 时,里面的作用最好改变布局 ,否则会占用等待时间,useLayoutEffect中进行DOM操作,这些DOM修改会与react做出的修改一起被一次性的渲染到页面上,只会产生一次回流、重绘,防止页面抖动

经验

  • 为了用户体验,优先使用 useEffect(优先渲染),因为大部分时候,我们不会去改变DOM
  • useLayoutEffect 会影响用户看到画面变化的时间

例子

  • useEffect
    import React, { useEffect, useState, useLayoutEffect, useRef } from 'react';
    import { render } from 'react-dom';function App() {const [count, setCount] = useState(0);useEffect(() => {if (count === 0) {const randomNum = 10 + Math.random()*200setCount(10 + Math.random()*200);}}, [count]);return (<div onClick={() => setCount(0)}>{count}</div>);
    }render(<App />, document.getElementById('root'));

    在线进行试验:React (forked) - StackBlitz

  • useLayoutEffect

    import React, { useEffect, useState, useLayoutEffect, useRef } from 'react';
    import { render } from 'react-dom';function App() {const [count, setCount] = useState(0);useLayoutEffect(() => {if (count === 0) {const randomNum = 10 + Math.random()*200setCount(10 + Math.random()*200);}}, [count]);return (<div onClick={() => setCount(0)}>{count}</div>);
    }render(<App />, document.getElementById('root'));

    在线验证:React (forked) - StackBlitz

http://www.lryc.cn/news/6884.html

相关文章:

  • NoSQL(非关系型数据库)与SQL(关系型数据库)的差别
  • new bing的申请与使用教程
  • yaml配置文件
  • 284. 顶端迭代器
  • 自学前端最容易犯的10个的错误,入门学前端快来看看
  • 【ADRC控制】使用自抗扰控制器调节起动机入口压力值
  • 剑指 Offer Day2——链表(简单)
  • Final Cut Pro 10.6.5
  • Modelsim仿真操作指导
  • 你知道这20个数组方法是怎么实现的吗?
  • 《系统架构设计》-01-架构和架构师概述
  • 第七届蓝桥杯省赛——5分小组
  • 中国专科医院行业市场规模及未来发展趋势
  • 【刷题笔记】--两数之和Ⅳ,从二叉树中找出两数之和
  • 浏览器渲染原理JavaScript V8引擎
  • 在TheSandbox 的「BOYS PLANET」元宇宙中与你的男孩们见面吧!
  • 数据结构与算法:java对象的比较
  • python(16)--类
  • CNI 网络流量分析(七)Calico 介绍与原理(二)
  • API安全的最大威胁:三体攻击
  • 分布式事务解决方案——TCC
  • ITSS认证分为几个级别,哪个级别最高
  • ZigBee案例笔记 - USART
  • java | 基于Redis的分布式锁实现①
  • 十六、基于FPGA的CRC校验设计实现
  • 2022爱分析 · DataOps厂商全景报告 | 爱分析报告
  • 京东前端react面试题及答案
  • TongWeb8数据源相关问题
  • 关于最近大热的AI,你怎么看?
  • 25.架构和软件产品线