【safari】react在safari浏览器中,遇到异步时间差的问题,导致状态没有及时更新到state,引起传参错误。如何解决

在safari浏览器中,可能会遇到异步时间差的问题,导致状态没有及时更新到state,引起传参错误。

PS:由于useState是一个普通的函数, 定义为() => void;因此此处不能用await/async替代setTimeout,只能用在返回值为Promise时

有问题的代码:

我们可以看到,setTimeout只传0,这个时候在谷歌浏览器是有效果的,能确保顺序正确,但是在safari浏览器下,obj的值没有办法及时更新上state。

typescript 复制代码
const columnsChange = ({ key, val }: { key: string | number; val: any }) => {
        const obj = {
            [key]: Array.isArray(val) && val?.length > 0 ? val : undefined
        };
        setFilters((f) => ({ ...f, ...obj }));
        setPagination({ pageNo: 1, pageSize: PAGE_SIZE });
        setTimeout(() => {
            run();
        }, 0);
    };

修改后的代码:

于是,我们尝试使用await/async去处理异步,但是由于setState是一个普通的函数, 定义为() => void;因此此处不能用await/async替代setTimeout,只能用在返回值为Promise时。因此不能这样做!

typescript 复制代码
const columnsChange = async ({ key, val }: { key: string | number; val: any }) => {
        const obj = {
            [key]: Array.isArray(val) && val?.length > 0 ? val : undefined
        };
        // 由于setState是一个普通的函数, 定义为() => void;因此此处不能用await/async替代setTimeout,只能用在返回值为Promise时
        await setFilters((f) => ({ ...f, ...obj }));
        setPagination({ pageNo: 1, pageSize: PAGE_SIZE });
        run();
    };
验证:我们通过查看useState的定义,查看Dispatch、SetStateAction的定义,可以看到都是() => void或者返回泛型S(这意味着如果我们要变更的状态不是promise,也不适用await写法)



正确的代码:

将异步时间微调大一些200ms

typescript 复制代码
const columnsChange = ({ key, val }: { key: string | number; val: any }) => {
        const obj = {
            [key]: Array.isArray(val) && val?.length > 0 ? val : undefined
        };
        // 由于setState是一个普通的函数, 定义为() => void;因此此处不能用await/async替代setTimeout,只能用在返回值为Promise时
        setFilters((f) => ({ ...f, ...obj }));
        setPagination({ pageNo: 1, pageSize: PAGE_SIZE });
        setTimeout(() => {
            run();
        }, 200);
    };
相关推荐
逆旅行天涯19 分钟前
【功能实现】axios实现动态数据
前端·javascript·vue.js
东离与糖宝32 分钟前
react 修改对象参数的值
前端·javascript·react.js
ohMyGod_1231 小时前
打卡53天------图论(应用题)
前端·javascript·算法
SuuuuuuuN1 小时前
web3js连接测试网并完成交易
前端·javascript·web3·区块链·reactjs
BHDDGT1 小时前
学习前端面试知识(16)
前端·学习
WSH2012ffff2 小时前
前端三剑客
前端
沐爸muba2 小时前
初识 Go 语言,环境配置有问题
开发语言·前端·后端·golang
让开,我要吃人了2 小时前
鸿蒙Harmony编程开发:服务端证书锁定防范中间人攻击示例
linux·前端·华为·移动开发·dubbo·harmonyos·鸿蒙
爱码网页成品2 小时前
HTML静态网页成品作业(HTML+CSS)——电影肖申克的救赎介绍设计制作(1个页面)
前端·css·html
工业甲酰苯胺3 小时前
优化系统性能:深入探讨Web层缓存与Redis应用的挑战与对策
前端·redis·缓存