[React]用 flushSync 同步更新 state

参考:使用 ref 操作 DOM -- React 中文文档

同时操作state和ref的情况还是有的,按我的原来的处理肯定是使用setTimeout了,看到官方有解决方案,摘录下来以便查看。

源代码就不完整贴了,直接看问题代码块:

javascript 复制代码
setTodos([ ...todos, newTodo]);
listRef.current.lastChild.scrollIntoView();

在 React 中,state 更新是排队进行的。在这个示例中会导致问题,因为 setTodos 不会立即更新 DOM。因此,当你将列表滚动到最后一个元素时,尚未添加待办事项。这就是为什么滚动总是"落后"一项的原因。

要解决此问题,你可以强制 React 同步更新("刷新")DOM。 为此,从 react-dom 导入 flushSync 并将 state 更新包裹 到 flushSync 调用中:

javascript 复制代码
flushSync(() => {
  setTodos([ ...todos, newTodo]);
});
listRef.current.lastChild.scrollIntoView();
相关推荐
diudiu_337 小时前
web漏洞--认证缺陷
java·前端·网络
阿珊和她的猫7 小时前
<video>` 和 `<audio>` 标签的常用属性解析
前端
LSL666_8 小时前
4 jQuery、JavaScript 作用域、闭包与 DOM 事件绑定
前端·javascript·html
yinuo8 小时前
前端跨页面通讯终极指南⑤:window.name 用法全解析
前端
小飞侠在吗8 小时前
vue computed 和 watch
前端·javascript·vue.js
yinuo8 小时前
前端跨页面通讯终极指南④:MessageChannel 用法全解析
前端
诸葛老刘8 小时前
next.js 框架中的约定的特殊参数名称
开发语言·javascript·ecmascript
前端布鲁伊8 小时前
聊聊前端容易翻车的“环境管理”
前端·面试
毕设十刻9 小时前
基于Vue的考勤管理系统8n7j8(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
coding随想9 小时前
掌控选区的终极武器:getSelection API的深度解析与实战应用
java·前端·javascript