react 18中,使用useRef 获取其他组件的dom并操作节点,flushSync强制同步更新useState

React 不允许组件访问其他组件的 DOM 节点。甚至自己的子组件也不行!这是故意的。Refs 是一种脱围机制,应该谨慎使用。手动操作 另一个 组件的 DOM 节点会使你的代码更加脆弱。

相反,想要 暴露其 DOM 节点的组件必须选择该行为。一个组件可以指定将它的 ref “转发”给一个子组件。

import { forwardRef, useRef } from 'react';const MyInput = forwardRef((props, ref) => {return <input {...props} ref={ref} />;
});export default function Form() {const inputRef = useRef(null);function handleClick() {inputRef.current.focus();}return (<><MyInput ref={inputRef} /><button onClick={handleClick}>聚焦输入框</button></>);
}

flushSync 强制 React 同步更新

import { useState, useRef } from 'react';
import { flushSync } from 'react-dom';export default function TodoList() {const listRef = useRef(null);const [text, setText] = useState('');const [todos, setTodos] = useState(initialTodos);function handleAdd() {const newTodo = { id: nextId++, text: text };flushSync(() => {setText('');setTodos([ ...todos, newTodo]);      });listRef.current.lastChild.scrollIntoView({behavior: 'smooth',block: 'nearest'});}return (<><button onClick={handleAdd}>添加</button><inputvalue={text}onChange={e => setText(e.target.value)}/><ul ref={listRef}>{todos.map(todo => (<li key={todo.id}>{todo.text}</li>))}</ul></>);
}let nextId = 0;
let initialTodos = [];
for (let i = 0; i < 20; i++) {initialTodos.push({id: nextId++,text: '待办 #' + (i + 1)});
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/46988.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

鹈鹕优化算法(POA)及其Python和MATLAB实现

鹈鹕优化算法&#xff08;Pelican Optimization Algorithm&#xff0c;简称POA&#xff09;是一种基于仿生学原理的优化算法&#xff0c;灵感来源于大自然中鹈鹕的觅食行为。POA被设计用于解决优化问题&#xff0c;尤其在连续型和离散型的优化问题中展现出了较好的性能。 ### …

单例模式-C#

在C#中实现单例模式&#xff0c;主要目的是确保一个类仅有一个实例&#xff0c;并提供一个全局访问点来获取这个实例。以下是一个简单的单例模式实现示例&#xff0c;它使用了一个私有静态变量来保存类的唯一实例&#xff0c;并提供了一个公有的静态方法来获取这个实例。此外&a…

【Unity C#基础】浅谈List底层逻辑

1.内部实现 List实际是通过数组来实现的&#xff0c;而不是链表。并且没设定初始容量的情况下&#xff0c;初始容量默认为0。 2.扩容 每次容量不够时&#xff0c;数组容量会扩充一倍。按照4、8、16、32、64、128、256……递增。 按照2的指数进行扩容可以为GC减少负担。 每…

CentOS 7 网络配置

如想了解请查看 虚拟机安装CentOS7 第一步&#xff1a;查看虚拟机网络编辑器、查看NAT设置 &#xff08;子网ID&#xff0c;网关IP&#xff09; 第二步&#xff1a;配置VMnet8 IP与DNS 注意事项&#xff1a;子网掩码与默认网关与 第一步 保持一致 第三步&#xff1a;网络配置…

客服新纪元:Transformer模型在自动化客户服务的革命性应用

客服新纪元&#xff1a;Transformer模型在自动化客户服务的革命性应用 随着人工智能技术的飞速发展&#xff0c;自动化客户服务已成为企业提升效率、降低成本的关键途径。Transformer模型&#xff0c;以其在处理序列数据方面的强大能力&#xff0c;正在自动化客户服务领域扮演…

掌握Xcode的魔术:自定义Storyboard的创建与管理

掌握Xcode的魔术&#xff1a;自定义Storyboard的创建与管理 在iOS应用开发中&#xff0c;Storyboard提供了一种直观的方式来设计和管理用户界面。通过Storyboard&#xff0c;开发者可以轻松地构建应用的视图控制器&#xff0c;同时定义它们之间的转换。然而&#xff0c;随着应…

用Pytorch实现线性回归(Linear Regression with Pytorch)

使用pytorch写神经网络的第一步就是需要准备好数据集&#xff0c;设计模型&#xff08;用于计算y_hat&#xff08;y的预测值&#xff09;&#xff09;&#xff0c;构造损失函数和优化器&#xff08;使用PyTorch API&#xff09;&#xff0c;写训练周期&#xff08;前馈&#xf…

Centos7 rpm 安装 Mysql 8.0.28

Centos7 rpm 安装 Mysql 8.0.28 一、检查系统是否已经安装了Mysql 如果安装了则卸载 [rootiZbp1byzaznzn9jncxr010Z /]# rpm -qa | grep mysql[rootiZbp1byzaznzn9jncxr010Z /]# rpm -qa | grep mariadb mariadb-libs-5.5.68-1.el7.x86_64如果安装了 mysql &#xff0c;maria…

2-36 基于matlab的流行学习算法程序

基于matlab的流行学习算法程序。通过GUI的形式将MDS、PCA、ISOMAP、LLE、Hessian LLE、Laplacian、Dissusion MAP、LTSA八种算法。程序以可视化界面进行展示&#xff0c;可直接调用进行分析。多种案例举例说明八种方法优劣&#xff0c;并且可设置自己数据进行分析。程序已调通&…

【12】奇偶数判断

奇偶数判断 题目描述 给定一个整数&#xff0c;判断该数是奇数还是偶数。如果 n n n 是奇数&#xff0c;输出 odd&#xff1b;如果 n n n 是偶数&#xff0c;输出 even。 输入格式 输入仅一行&#xff0c;一个整数 n n n。 输出格式 输出仅一行&#xff0c;如果 n n …

网络安全工作者如何解决网络拥堵

网络如同现代社会的血管&#xff0c;承载着信息的血液流动。然而&#xff0c;随着数据流量的激增&#xff0c;网络拥堵已成为不容忽视的问题&#xff0c;它像是一场数字世界的交通堵塞&#xff0c;减缓了信息传递的速度&#xff0c;扰乱了网络空间的秩序。作为网络安全的守护者…

vue2页面渲染 两个数据一行 怎么渲染

let data[“办公电脑”,“办公纸品”,“个护用品”,“销毁设备”,“桌面文具”,] 在 Vue 2 中&#xff0c;你可以使用 ​v-for​ 指令来遍历数据数组&#xff0c;并使用 CSS 来控制每行显示两个数据项。以下是一个简单的示例&#xff0c;展示了如何在 Vue 2 中实现这个需求&am…

Laravel速率限制:保护API的盾牌

Laravel速率限制&#xff1a;保护API的盾牌 在构建API时&#xff0c;速率限制&#xff08;Rate Limiting&#xff09;是一个关键的安全特性&#xff0c;它能够防止API被滥用或遭受恶意攻击。Laravel框架提供了一种简单而强大的机制来实现API速率限制&#xff0c;确保你的应用程…

C++ Primer:2.6 自定义数据结构

其他章节&#xff1a;C Primer 学习心得 类以关键字struct开始&#xff0c;紧跟着类名和类体&#xff08;类体部分可以为空&#xff09;。类体有花括号包围形成了一个新的作用域。内内部定义的名字必须唯一&#xff0c;可以与类外部定义的名字重复。 类体右侧表示结束的花括号…

通过路由上的参数生成唯一md5和路由上token做验证

前言&#xff1a;有这么一个场景&#xff0c;路由上有很多的参数&#xff0c;同时有一个token字段&#xff0c;通过路由上的mediaId,X-Test-Timestamp,ui_control 这三个字段生成一个md5值&#xff0c;然后和token要、做一个对比&#xff0c;看是否是通过这三个字段生成的token…

鸿蒙语言基础类库:【@system.brightness (屏幕亮度)】

屏幕亮度 说明&#xff1a; 从API Version 7 开始&#xff0c;该接口不再维护&#xff0c;推荐使用新接口[ohos.brightness]。本模块首批接口从API version 3开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。 导入模块 import brightness from sy…

MVC、MVP和MVVM这三种设计模式的区别

详谈MVC、MVP 和 MVVM MVC、MVP 和 MVVM 这三种设计模式的区别1. 角色职责2. 数据绑定3. 性能和可测试性4. 复杂性5. 技术依赖6. 综合比较 总结如何选择 MVC、MVP 和 MVVM 这三种设计模式的区别 1. 角色职责 MVC 模型&#xff08;Model&#xff09;&#xff1a;负责数据处理和…

【算法】LRU缓存

难度&#xff1a;中等 题目&#xff1a; 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类&#xff1a; LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中&#xff0c;…

多级表头固定列问题

父级的width&#xff0c;是需要固定的列的width的总和 参考&#xff1a; el-table 多级表头下对应列的固定

1.3Zygote

Zygote 是 Android 系统中一个关键的进程&#xff0c;负责快速创建新应用进程。它的名字来源于生物学中的“合子”&#xff0c;象征着它是所有应用进程的起源。以下是对 Zygote 的详细解析&#xff1a; Zygote 的作用 预加载&#xff1a; Zygote 在系统启动时预加载了一些常用…