React Hooks批量更新问题

React 版本17.0.2

javascript 复制代码
import React, { useState } from 'react';

const Demo = () => {
    const [count, setCount] = useState(0);
    const [count1, setCount1] = useState(0);
    const [count2, setCount2] = useState(0);

    console.log('===Demo==');

    const add = async () => {
        await 10;
        setCount(count + 1);
        setCount1(count1 + 1);
        setCount2(count2 + 1);
    };

    return (
        <div>
            <div onClick={add}>button</div>
            <div>{count}</div>
            <div>{count1}</div>
            <div>{count2}</div>
        </div>
    );
};

export default Demo;

每次点击button ,log会执行3次,当我们把async方法里面的await去掉,让他变成正常方法,那么点击button就会执行一次。

同样代码在React 版本18.2.0时候点击button,log只会打印一次。

再次修改代码对同一个状态同时执行多次更改

javascript 复制代码
import React, { useState } from 'react';

const Demo = () => {
    const [count, setCount] = useState(0);

    console.log('===Demo==');

    const add = async () => {
        await 10;
        setCount(count + 1);
        setCount(count + 1);
        setCount(count + 1);
        setCount(count + 1);
        setCount(count + 1);
        setCount(count + 1);
    };

    return (
        <div>
            <div onClick={add}>button</div>
            <div>{count}</div>
        </div>
    );
};

export default Demo;

React 17.0.2 log会打次2次,也就是对于同一状态同时多次修改,那么React会合并一起更改,log打印两次是因为在开发环境下,会多执行一次。

React18,还是只会打印一次log。

总结:

React 17.0.2 在异步方法中,多个状态同时修改会造成页面刷新多次,同一状态同时多次修改页面只会刷新一次

React 18 默认在异步方法中开启了批量更新没有问题。

React 17.0.2解决方案:使用unstable_batchedUpdates

javascript 复制代码
import React, { useState } from 'react';
import { unstable_batchedUpdates } from 'react-dom'; // 批量更新状态时使用

const Demo = () => {
    const [count, setCount] = useState(0);
    const [count1, setCount1] = useState(0);
    const [count2, setCount2] = useState(0);

    console.log('===Demo==');

    const add = async () => {
        await 10;
        unstable_batchedUpdates(() => {
            setCount(count + 1);
            setCount1(count1 + 1);
            setCount2(count2 + 1);
        });
    };

    return (
        <div>
            <div onClick={add}>button</div>
            <div>{count}</div>
            <div>{count1}</div>
            <div>{count2}</div>
        </div>
    );
};

export default Demo;

log只会打印一次

相关推荐
IT_陈寒2 小时前
SpringBoot这个自动配置坑我跳了三次
前端·人工智能·后端
kyriewen2 小时前
我用 AI 一周写完了整个项目,上线第一天就崩了——这是我踩过最贵的 5 个坑
前端·javascript·ai编程
Larcher3 小时前
AI Loop:让AI像人一样自主完成任务的核心机制
javascript·人工智能·设计模式
默_笙3 小时前
🃏 JS 只有 8 种数据类型,但我花了 2 天才搞懂 null 和 undefined 的区别
javascript
牧艺3 小时前
从零到协同:构建类飞书在线文档系统的五个技术重难点
前端·人工智能
jump_jump3 小时前
流式 HTML:从 htmx 片段装配到浏览器原生增量渲染
javascript·性能优化·前端工程化
红尘散仙3 小时前
想写一个像样的终端 App?试试把 React 的开发体验搬进 Rust TUI
前端·rust
袋鼠云数栈UED团队4 小时前
一套 Spec-First 的 AI 编程工作流
前端·人工智能
袋鼠云数栈前端4 小时前
一套 Spec-First 的 AI 编程工作流
前端·ai+
angerdream4 小时前
Android手把手编写儿童手机远程监控App之vue3 路由守卫
前端