react合成事件

react源码要封装合成事件优势

  • 通过事件委托机制,将所有事件处理程序附加到根元素上,而不是每个子元素;提高了性能和内存使用效率,特别是在有大量元素的情况下
  • 重新封装的合成事件消除了浏览器的差异,兼容性好

如何实现的

  • 事件注册: 在createRoot之前就会调用
scss 复制代码
// 当前React18提供了以下5个合成事件
Plugin SimpleEventPlugin.registerEvents(); // SimpleEventPlugin 处理一些常用的基础事件,详细请参见DOMEventProperties.js 中的registerSimpleEvents注册函数 
EnterLeaveEventPlugin.registerEvents(); // 鼠标移动事件 
ChangeEventPlugin.registerEvents(); // 修改事件 
SelectEventPlugin.registerEvents(); // 处理选择事件 
BeforeInputEventPlugin.registerEvents(); // 处理控件输入前事件
  • 事件绑定
scss 复制代码
const createRoot(rootContainerElement){
   .....
   // 在根元素上进行事件绑定
   listenToAllSupportedEvents(rootContainerElement);
}
  • 事件触发
scss 复制代码
 export function dispatchEvent(
  domEventName: DOMEventName,
  eventSystemFlags: EventSystemFlags,
  targetContainer: EventTarget,
  nativeEvent: AnyNativeEvent,
): void {
  ......
  // 收集沿途事件、构建合成事件、遍历捕获事件、遍历冒泡事件
  dispatchEventForPluginEventSystem(
    domEventName,
    eventSystemFlags,
    nativeEvent,
    null,
    targetContainer,
  );
}

function dispatchEventsForPlugins(
  domEventName: DOMEventName,
  eventSystemFlags: EventSystemFlags,
  nativeEvent: AnyNativeEvent,
  targetInst: null | Fiber,
  targetContainer: EventTarget,
): void {
  const nativeEventTarget = getEventTarget(nativeEvent);
  // 存放事件的队列
  const dispatchQueue: DispatchQueue = [];
  // 收集沿途事件、构建合成事件
  extractEvents(
    dispatchQueue,
    domEventName,
    targetInst,
    nativeEvent,
    nativeEventTarget,
    eventSystemFlags,
    targetContainer,
  );
  // 遍历捕获事件、遍历冒泡事件
  processDispatchQueue(dispatchQueue, eventSystemFlags);
}

大致流程图如下:

文章借鉴 juejin.cn/post/739947...

相关推荐
康一夏2 小时前
React面试题,封装useEffect
前端·javascript·react.js
社恐的下水道蟑螂4 小时前
深入掌握 AI 全栈项目中的路由功能:从基础到进阶的全面解析
前端·react.js·全栈
FanetheDivine4 小时前
图片标注框选组件
前端·react.js
子玖4 小时前
antd6的table排序功能
前端·react.js
徐同保5 小时前
react两个组件中间加一个可以拖动跳转左右大小的功能
前端·javascript·react.js
2501_948194986 小时前
RN for OpenHarmony AnimeHub项目实战:正在热播页面开发
javascript·react native·react.js
2501_944521006 小时前
rn_for_openharmony商城项目app实战-语言设置实现
javascript·数据库·react native·react.js·harmonyos
溪海莘7 小时前
React入门:跟读官方快速入门教程(前端小白)
前端·react.js·前端框架
cauyyl7 小时前
react 项目检查国际化配置脚本
前端·react.js·前端框架
康一夏8 小时前
React面试题,useRef和普通变量的区别
前端·javascript·react.js