react 19 useOptimistic 竞争更新乐观值时阻塞

react 19 刚刚出,我在官网上调试这个 useOptimistic api 时,发现了一个竞争调用时的阻塞状态。当连续多次调用 updateFn 参数,且每次更新时间较长时,乐观状态的更新被阻塞了。

前往官网 useOptimistic 一节,修改末尾 demo 中 actions.js 代码如下:

js 复制代码
let i = 0;
const time = [10_000,6_000,10_000];
export async function deliverMessage(message) {
  await new Promise((res) => setTimeout(res, time[i++] ?? 1000));
  return message;
}

此时前三次的更新时间变为 10s、6s、10s,当我连续依次输入 1、2、3 后,触发三次乐观更新,视图在某个时间点出现如下的结果:

实际上,第二次和第一次更新已经完成,第三次更新还在进行中。可是乐观更新的结果没办法进行 diff 区分,乐观值被更慢的更新严重阻塞。

新 api 还是慎用

相关推荐
Asurplus5 分钟前
【VUE】15、安装包管理工具yarn
前端·vue.js·npm·node.js·yarn
liangshanbo12157 分钟前
Mac M3 安装 Antigravity Agent “已损坏“ 问题解决方案
前端·macos·antigravity
sszdlbw8 分钟前
前后端在服务器的部署
运维·服务器·前端·后端
马卫斌 前端工程师10 分钟前
vue 多个请求要同时拉取数据,写一个方法
前端·javascript·vue.js
苏打水com11 分钟前
第十篇:Day28-30 工程化优化与部署——从“能跑”到“好用”(对标职场“项目上线”需求)
前端·css·vue·html·js
写代码的皮筏艇12 分钟前
react hooks中的useState
前端·javascript
fruge13 分钟前
React Fiber 架构详解:为什么它能解决页面卡顿问题?
前端·react.js·架构
时717 分钟前
iframe 事件无法冒泡到父窗口的解决方案
前端·element
用户66006766853917 分钟前
纯 CSS 复刻星战开场:让文字在宇宙中滚动
前端·css