react的合成事件如何形容
React合成事件是React模擬原生DOM事件所有能力的事件對象,即瀏覽器原生事件的跨瀏覽器包裝器;它根據W3C規範來定義合成事件,相容於所有瀏覽器,擁有與瀏覽器原生事件相同的介面。在React中,所有事件都是合成的,不是原生DOM事件,但可以透過「e.nativeEvent」屬性來取得DOM事件。
本教學操作環境:Windows7系統、react18版、Dell G3電腦。
一、合成事件是什麼
React基於瀏覽器的事件機製本身實作了一套事件機制,包括事件註冊、事件的合成、事件冒泡、事件派發等
#在React中這套事件機制稱為合成事件
#合成事件(SyntheticEvent)
React 合成事件(SyntheticEvent)是React 模擬原生DOM 事件所有能力的事件對象,即瀏覽器原生事件的跨瀏覽器包裝器。它根據 W3C 規格 來定義合成事件,相容於所有瀏覽器,並擁有與瀏覽器原生事件相同的介面。例如
const button = <button onClick={handleClick}>按钮</button>
在 React 中,所有事件都是合成的,不是原生 DOM 事件,但可以透過 e.nativeEvent 屬性取得 DOM 事件。例如:
const handleClick = (e) => console.log(e.nativeEvent);; const button = <button onClick={handleClick}>按钮</button>
從上面可以看到React事件和原生事件也非常的相似,但也有一定的差異:
事件名稱命名方式不同
// 原生事件绑定方式 <button onclick="handleClick()">按钮命名</button> // React 合成事件绑定方式 const button = <button onClick={handleClick}>按钮命名</button>
事件處理函數書寫不同
// 原生事件 事件处理函数写法 <button onclick="handleClick()">按钮命名</button> // React 合成事件 事件处理函数写法 const button = <button onClick={handleClick}>按钮命名</button>
雖然onclick看似綁定到DOM元素上,但實際上並不會把事件代理函數直接綁定到真實的節點上,而是把所有的事件綁定到結構的最外層,使用一個統一的事件去監聽。 【相關推薦:Redis影片教學、程式設計教學】
這個事件監聽器上維持了一個映射來保存所有元件內部的事件監聽和處理函數。當元件掛載或卸載時,只是在這個統一的事件監聽器上插入或刪除一些物件。
當事件發生時,首先被這個統一的事件監聽器處理,然後在映射裡找到真正的事件處理函數並呼叫。這樣做簡化了事件處理和回收機制,效率也大大提升。
二、執行順序
關於React合成事件與原生事件執行順序,可以看看下面一個例子:
import React from 'react'; class App extends React.Component{ constructor(props) { super(props); this.parentRef = React.createRef(); this.childRef = React.createRef(); } componentDidMount() { console.log("React componentDidMount!"); this.parentRef.current?.addEventListener("click", () => { console.log("原生事件:父元素 DOM 事件监听!"); }); this.childRef.current?.addEventListener("click", () => { console.log("原生事件:子元素 DOM 事件监听!"); }); document.addEventListener("click", (e) => { console.log("原生事件:document DOM 事件监听!"); }); } parentClickFun = () => { console.log("React 事件:父元素事件监听!"); }; childClickFun = () => { console.log("React 事件:子元素事件监听!"); }; render() { return ( <div ref={this.parentRef} onClick={this.parentClickFun}> <div ref={this.childRef} onClick={this.childClickFun}> 分析事件执行顺序 </div> </div> ); } } export default App;
輸出順序為:
原生事件:子元素 DOM 事件监听! 原生事件:父元素 DOM 事件监听! React 事件:子元素事件监听! React 事件:父元素事件监听! 原生事件:document DOM 事件监听!
可以得出以下結論:
React 所有事件都掛載在document 物件上
當真實DOM元素觸發事件,會冒泡到document 物件後,再處理React 事件
所以會先執行原生事件,然後處理React 事件
最後真正執行document 上掛載的事件
對應程序如圖所示:
- 阻止合成事件間的冒泡,用e.stopPropagation()
- 阻止合成事件與最外層document 上的事件間的冒泡,用e.nativeEvent.stopImmediatePropagation()
- 阻止合成事件與除最外層document上的原生事件上的冒泡,透過判斷e.target來避免
- React 上註冊的事件最終會綁定在document這個DOM 上,而不是React 元件對應的DOM(減少記憶體開銷就是因為所有的事件都綁定在document 上,其他節點沒有綁定事件)
- React 本身實作了一套事件冒泡機制,所以這就是為什麼我們event.stopPropagation()無效的原因。
- React 透過佇列的形式,從觸發的元件向父元件回溯,然後呼叫他們JSX 中定義的callback
- React 有一套自己的合成事件SyntheticEvent
document.body.addEventListener('click', e => { if (e.target && e.target.matches('div.code')) { return; } this.setState({ active: false, }); }); }
#三、總結
React事件機制總結如下:程式設計基礎影片)
以上是react的合成事件如何形容的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

如何利用React和WebSocket建立即時聊天應用程式引言:隨著網路的快速發展,即時通訊越來越受到人們的關注。即時聊天應用程式已成為現代社交和工作生活中不可或缺的一部分。本文將介紹如何利用React和WebSocket建立一個簡單的即時聊天應用,並提供具體的程式碼範例。一、技術準備在開始建立即時聊天應用之前,我們需要準備以下技術和工具:React:一個用於構建

React前後端分離指南:如何實現前後端的解耦和獨立部署,需要具體程式碼範例在當今的Web開發環境中,前後端分離已經成為一種趨勢。透過將前端和後端程式碼分開,可以讓開發工作更加靈活、高效,並且方便進行團隊協作。本文將介紹如何使用React實現前後端分離,從而實現解耦和獨立部署的目標。首先,我們要先理解什麼是前後端分離。傳統的Web開發模式中,前端和後端是耦合在

如何利用React和Flask建構簡單易用的網路應用引言:隨著網路的發展,網路應用的需求也越來越多樣化和複雜化。為了滿足使用者對於易用性和效能的要求,使用現代化的技術堆疊來建立網路應用變得越來越重要。 React和Flask是兩個在前端和後端開發中非常受歡迎的框架,它們可以很好的結合在一起,用來建立簡單易用的網路應用。本文將詳細介紹如何利用React和Flask

如何利用React和RabbitMQ建立可靠的訊息傳遞應用程式引言:現代化的應用程式需要支援可靠的訊息傳遞,以實現即時更新和資料同步等功能。 React是一種流行的JavaScript庫,用於建立使用者介面,而RabbitMQ是一種可靠的訊息傳遞中間件。本文將介紹如何結合React和RabbitMQ建立可靠的訊息傳遞應用,並提供具體的程式碼範例。 RabbitMQ概述:

React響應式設計指南:如何實現自適應的前端佈局效果隨著行動裝置的普及和使用者對多螢幕體驗的需求增加,響應式設計成為了現代前端開發的重要考量之一。而React作為目前最受歡迎的前端框架之一,提供了豐富的工具和元件,能夠幫助開發人員實現自適應的佈局效果。本文將分享一些關於使用React實現響應式設計的指南和技巧,並提供具體的程式碼範例供參考。使用React的Fle

React程式碼偵錯指南:如何快速定位並解決前端bug引言:在開發React應用程式時,經常會遇到各種各樣的bug,這些bug可能會使應用程式崩潰或導致不正確的行為。因此,掌握調試技巧是每個React開發者必備的能力。本文將介紹一些定位和解決前端bug的實用技巧,並提供具體的程式碼範例,幫助讀者快速定位和解決React應用程式中的bug。一、調試工具的選擇:在Re

ReactRouter使用指南:如何實現前端路由控制隨著單頁應用的流行,前端路由成為了一個不可忽視的重要部分。 ReactRouter作為React生態系統中最受歡迎的路由庫,提供了豐富的功能和易用的API,使得前端路由的實作變得非常簡單和靈活。本文將介紹ReactRouter的使用方法,並提供一些具體的程式碼範例。安裝ReactRouter首先,我們需要

如何利用React和GoogleBigQuery建立快速的資料分析應用引言:在當今資訊爆炸的時代,資料分析已經成為了各產業中不可或缺的環節。而其中,建構快速、有效率的資料分析應用則成為了許多企業和個人追求的目標。本文將介紹如何利用React和GoogleBigQuery結合來建立快速的資料分析應用,並提供詳細的程式碼範例。一、概述React是用來構建
