React 中的事件处理

embedded/2024/10/22 12:35:37/

React 中是如何处理事件的,现在下面简单的一段代码:

export default function App() {const AList = lazy(()=>import('./List.js'))const r = useRef(null)  const [show, setShow] = useState(false);return (<><button onFocus={()=>{setShow(!show)}} >加载组件</button>{show ? <Suspense fallback="loading"><AList items={[{id:1, text:"123"}]}>asdf</AList></Suspense>:""}</>);
}

代码为 Button 绑定了 onFocus 事件,这里用 onFocus 是为了方便 debug。如果做一个框架要接管所有的事件处理,我们想一下应该如何处理,可以通过代理的方式,把所有可以监听到的事件交给代理去处理,最后在交给框架组件上绑定的对应事件进行处理。由于 JS 是冒泡事件模型,所有事件都会向上传递,只要监听最顶层容器就可以监听到所有事件,当点击发生的时候调用目标组件绑定的事件。

在这里插入图片描述
我们看一下,React 中怎么处理的。

组件注册事件

创建 Element,添加 props,这个 props 中就是 Focus 方法,将最终方法于 Element 绑定并包存在 Fiber 上。
在这里插入图片描述
绑定代码
在这里插入图片描述

Root 代理所有事件

创建 Root 时会监听所有事件:
在这里插入图片描述
方法中 loop 所有 Html 原生事件

在这里插入图片描述

事件触发

Focus 事件触发时,会执行 dispatchDiscreteEvent 方法,这个方法在 Root 代理监听时进行的绑定。
在这里插入图片描述
获取组件事件处理方法,这个方法在组件创建时进行的绑定。
在这里插入图片描述

总结

React 事件机制是一个代理模式,所有处理都由根组件监听并进行分发处理。


http://www.ppmy.cn/embedded/51222.html

相关文章

探索Sass:CSS的强大预处理器

探索Sass&#xff1a;CSS的强大预处理器 Sass&#xff08;Syntactically Awesome Stylesheets&#xff09;是一个CSS预处理器&#xff0c;可以使CSS更加强大、简洁和高效。通过引入变量、嵌套、混合、继承等特性&#xff0c;Sass极大地改善了传统CSS的编写和管理方式。本文将深…

ROS中的TF是什么

在ROS (Robot Operating System) 中&#xff0c;tf::TransformBroadcaster 是一个用于发布坐标变换信息的重要类&#xff0c;尤其在处理机器人定位和导航数据时非常常见。tf::TransformBroadcaster 对象允许你广播从一个坐标系到另一个坐标系的变换关系&#xff0c;这对于多传感…

动手学深度学习(Pytorch版)代码实践 -卷积神经网络-21多输入多输出通道

21多输入多输出通道 import torch from d2l import torch as d2ldef corr2d(X, K):"""计算二维互相关运算"""h, w K.shapeY torch.zeros((X.shape[0] - h 1, X.shape[1] - w 1))for i in range(Y.shape[0]):for j in range(Y.shape[1]):Y[i,…

人工智能需要学习的知识有哪些?

人工智能需要学习的知识有哪些? 人工智能的学习涉及多个学科领域的知识&#xff0c;包括计算机科学、数学、机器学习、深度学习等。接下来具体分析一下: 一、计算机科学基础 计算机操作系统&#xff1a;学习计算机的基本工作原理&#xff0c;包括操作系统的功能、结构和管理。…

Qwen2大语言模型微调、导出、部署实践

上篇文章&#xff1a; Qwen1.5大语言模型微调实践_qwen1.5 7b微调-CSDN博客 我们介绍了Qwen1.5 大语言模型使用LLaMA-Factory 来微调&#xff0c;这篇文章我们介绍一下微调后模型的导出、部署。 一、模型导出 在webui 界面训练好模型之后点击“Export”选项卡&#xff0c;然…

【博客719】时序数据库基石:LSM Tree的增删查改

时序数据库基石&#xff1a;LSM Tree的增删查改 LSM结构 LSM树将任何的对数据操作都转化为对内存中的Memtable的一次插入。Memtable可以使用任意内存数据结构&#xff0c;如HashTable&#xff0c;BTree&#xff0c;SkipList等。对于有事务控制需要的存储系统&#xff0c;需要在…

如何验证Rust中的字符串变量在超出作用域时自动释放内存?

讲动人的故事,写懂人的代码 在公司内部的Rust培训课上,讲师贾克强比较了 Rust、Java 和 C++ 三种编程语言在变量越过作用域时自动释放堆内存的不同特性。 Rust 通过所有权系统和借用检查,实现了内存安全和自动管理,从而避免了大部分内存泄漏。Rust 自动管理标准库中数据类…

Oracle 入门--前提

目录 1.sqlplus 2.dual是什么&#xff1f; 3.SQL语句的种类 4.Oracle是如何工作的 5.Oracle查看配置文件 6.修改配置文件 7.常用的参数设置 1.sqlplus 管理数据库&#xff1a;启动&#xff0c;关闭&#xff0c;创建&#xff0c;删除对象......查看数据库的运行状态&…