react 18 事件研究之原生事件和react合成事件触发顺序

第一步

首先我们先写一个在按钮上触发合成事件和原生事件的代码。

javascript 复制代码
import React, {useEffect, useRef} from 'react'
import { createRoot} from 'react-dom/client'


const App = () => {  
  const buttonRef = useRef(null);

  useEffect(()=>{
    buttonRef.current.addEventListener('click',()=>{
      console.log('原始冒泡');
    })
    buttonRef.current.addEventListener('click',()=>{
      console.log('原始捕获');
    }, true)
    return ()=>{
      buttonRef.current.removeEventListener('click');
    }
  },[])

  const onClick = () => {
    console.log('react冒泡');
  }

# const onClickCapture = () => {
    console.log('react捕获');
  }

  return(
    <button onClick={onClick} onClickCapture={onClickCapture} ref={buttonRef} >开始</button>
  )
}

const root = document.getElementById('app')
createRoot(root).render(<App></App>)

上面的代码在 button 元素上面绑定了react onClick 和 onClickCapture 两个合成事件,以及通过 addEventListener绑定了两个原生事件。 如果此时我们点击 button 按钮,四个打印的顺序会是什么样子的呢? 要回答上面的问题,我们要知道什么是捕获事件和冒泡事件,然后我们还需要研究下 react 的合成事件机制。

浏览器捕获事件和冒泡事件

上面的流程图为我们展示了 button 触发点击事件时,整个事件的流程,首先从 window 开始捕获,最后捕获到 button 上面,这是一个完整的捕获流程,接着开始冒泡流程,首先从 button 开始冒泡,最后冒泡到 window 上面最后结束。

react 合成事件

可以看到,react 其实帮我们把所有的事件都在捕获和冒泡阶段去代理,这样我们在代码中写的 onClick 和 onClickCapture 两个事件其实并没有去真正的走一遍监听流程,而是在事件触发后,由 react 代理事件去处理,最后找到对应元素上面真正要执行的事件处理函数。

所以上面代码的打印顺序是

react 捕获, 原始捕获,原始冒泡,react 冒泡

相关推荐
程序猿小D4 分钟前
第二百六十七节 JPA教程 - JPA查询AND条件示例
java·开发语言·前端·数据库·windows·python·jpa
奔跑吧邓邓子36 分钟前
npm包管理深度探索:从基础到进阶全面教程!
前端·npm·node.js
前端李易安1 小时前
ajax的原理,使用场景以及如何实现
前端·ajax·okhttp
汪子熙1 小时前
Angular 服务器端应用 ng-state tag 的作用介绍
前端·javascript·angular.js
Envyᥫᩣ2 小时前
《ASP.NET Web Forms 实现视频点赞功能的完整示例》
前端·asp.net·音视频·视频点赞
Мартин.6 小时前
[Meachines] [Easy] Sea WonderCMS-XSS-RCE+System Monitor 命令注入
前端·xss
昨天;明天。今天。7 小时前
案例-表白墙简单实现
前端·javascript·css
数云界7 小时前
如何在 DAX 中计算多个周期的移动平均线
java·服务器·前端
风清扬_jd7 小时前
Chromium 如何定义一个chrome.settingsPrivate接口给前端调用c++
前端·c++·chrome
安冬的码畜日常7 小时前
【玩转 JS 函数式编程_006】2.2 小试牛刀:用函数式编程(FP)实现事件只触发一次
开发语言·前端·javascript·函数式编程·tdd·fp·jasmine