摘要:事件簡介事件是合成事件,所有事件都自動綁定到最外層上。支持事件的冒泡機制,我們可以使用和來中斷它。這樣做簡化了事件處理和回收機制,效率也有很大提升。事件類型合成事件的事件類型是原生事件類型的一個子集。
React事件簡介
React事件是合成事件,所有事件都自動綁定到最外層上。因為Virtual DOM 在內(nèi)存中是以對象的形式存在的,所以React 基于 Virtual DOM 實現(xiàn)了一個 SyntheticEvent (合成事件)層,我們所定義的事件 處理器會接收到一個 SyntheticEvent 對象的實例。支持事件的冒泡機制,我 們可以使用 stopPropagation() 和 preventDefault() 來中斷它。沒有兼容問題。
事件綁定?
事件綁定的方式與原生事件綁定相似,但是必須使用駝峰的形式來書寫事件的屬性名(比如 onClick);
React 并不會像 DOM0 級事件那樣將事件處理器直接綁定到 HTML 元素之上,而是一個函數(shù)指針:
button onclick="handleClick()">Test //dom0合成事件的實現(xiàn)機制
在 React 底層,主要對合成事件做了兩件事:事件委派和自動綁定。
1.事件委派
React并不會把事件處理函數(shù)直接綁定到真實的節(jié)點上,而是把所有事件綁定到結構的最外層,使用一個統(tǒng)一的事件監(jiān)聽器,這個事件監(jiān)聽器上維持了一個映射來保存所有組件內(nèi)部的事件監(jiān)聽和處理函數(shù)。當組件掛載或卸載時,只是 在這個統(tǒng)一的事件監(jiān)聽器上插入或刪除一些對象;當事件發(fā)生時,首先被這個統(tǒng)一的事件監(jiān)聽器 處理,然后在映射里找到真正的事件處理函數(shù)并調(diào)用。這樣做簡化了事件處理和回收機制,效率 也有很大提升。
2. 自動綁定
在 React 組件中,每個方法的上下文都會指向該組件的實例,即自動綁定this為當前組件。但是使用 ES6 classes 或者純函數(shù)時,需要手動實現(xiàn)this的綁定。具體有如下方法:
1》通過bind方法實現(xiàn);每次重新渲染時,都會生成一個新的函數(shù)實例保存在listenerBank中,浪費內(nèi)存
render() { // 通過bind方法實現(xiàn),可以傳遞參數(shù) return ; } render() {//不傳遞參數(shù)時,也可以使用::代替 return ; }
2》構造器內(nèi)使用bind綁定;不用每次調(diào)用都綁定。推薦
import React, { Component } from "react"; class App extends Component { constructor(props) { super(props); this.handleClick = this.handleClick.bind(this); } handleClick(e) { console.log(e); } render() { return ; } }
3》箭頭函數(shù)
class App extends Component { //不能帶參數(shù) const handleClick = (e) => { console.log(e); }; render() { return ; } }
class App extends Component { //也是每次渲染都會生成新的函數(shù)實例 handleClick(e) { console.log(e); } render() { return } }對比React合成事件與JavaScript原生事件
對于無法使用 React 合成事件的場景,我們還需要使用原生事件來完成。從 4 個方面來對比 React 合成事件與 JavaScript 原生事件。
1.事件傳播與阻止事件傳播
瀏覽器原生 DOM 事件的傳播可以分為 3 個階段:事件捕獲階段、目標對象本身的事件處理程序調(diào)用以及事件冒泡。將 e.addEventListener() 的第三 個參數(shù)設置為 true 時,可以為事件注冊捕獲階段,但是ie9一下不支持,所以沒什么意義。react只提供了事件冒泡機制,通過e.prevent- Default() 即可。阻止原生事件傳播需要使用 e.preventDefault(),不過對于不支持該方法的瀏覽器(IE9 以 下),只能使用 e.cancelBubble = true 來阻止。
2.事件類型
React 合成事件的事件類型是 JavaScript 原生事件類型的一個子集。
3.事件綁定方式
受到 DOM 標準的影響,綁定瀏覽器原生事件的方式也有很多種,具體如下所示。
1》直接在 DOM 元素中綁定:
2》在 JavaScript 中,通過為元素的事件屬性賦值的方式實現(xiàn)綁定:
el.onclick = e => { console.log(e); }
3》通過事件監(jiān)聽函數(shù)來實現(xiàn)綁定:
el.addEventListener("click", () => {}, false); el.attachEvent("onclick", () => {});
相比而言,React 合成事件的綁定方式則簡單得多:
4.事件對象
原生 DOM 事件對象在 W3C 標準和 IE 標準下存在著差異。在低版本的 IE 瀏覽器中,只能
使用 window.event 來獲取事件對象。而在 React 合成事件系統(tǒng)中,不存在這種兼容性問題,在事
件處理函數(shù)中可以得到一個合成事件對象。
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/105526.html
摘要:事件簡介事件是合成事件,所有事件都自動綁定到最外層上。支持事件的冒泡機制,我們可以使用和來中斷它。這樣做簡化了事件處理和回收機制,效率也有很大提升。事件類型合成事件的事件類型是原生事件類型的一個子集。 React事件簡介 React事件是合成事件,所有事件都自動綁定到最外層上。因為Virtual DOM 在內(nèi)存中是以對象的形式存在的,所以React 基于 Virtual DOM 實現(xiàn)了...
摘要:因為版本將真正廢棄這三生命周期到目前為止,的渲染機制遵循同步渲染首次渲染,更新時更新時卸載時期間每個周期函數(shù)各司其職,輸入輸出都是可預測,一路下來很順暢。通過進一步觀察可以發(fā)現(xiàn),預廢棄的三個生命周期函數(shù)都發(fā)生在虛擬的構建期間,也就是之前。 showImg(https://segmentfault.com/img/bVbweoj?w=559&h=300); 背景 前段時間準備前端招聘事項...
摘要:聲明的變量不得改變值,這意味著,一旦聲明變量,就必須立即初始化,不能留到以后賦值。 雖然今年沒有換工作的打算 但為了跟上時代的腳步 還是忍不住整理了一份最新前端知識點 知識點匯總 1.HTML HTML5新特性,語義化瀏覽器的標準模式和怪異模式xhtml和html的區(qū)別使用data-的好處meta標簽canvasHTML廢棄的標簽IE6 bug,和一些定位寫法css js放置位置和原因...
摘要:聲明的變量不得改變值,這意味著,一旦聲明變量,就必須立即初始化,不能留到以后賦值。 雖然今年沒有換工作的打算 但為了跟上時代的腳步 還是忍不住整理了一份最新前端知識點 知識點匯總 1.HTML HTML5新特性,語義化瀏覽器的標準模式和怪異模式xhtml和html的區(qū)別使用data-的好處meta標簽canvasHTML廢棄的標簽IE6 bug,和一些定位寫法css js放置位置和原因...
摘要:聲明的變量不得改變值,這意味著,一旦聲明變量,就必須立即初始化,不能留到以后賦值。 雖然今年沒有換工作的打算 但為了跟上時代的腳步 還是忍不住整理了一份最新前端知識點 知識點匯總 1.HTML HTML5新特性,語義化瀏覽器的標準模式和怪異模式xhtml和html的區(qū)別使用data-的好處meta標簽canvasHTML廢棄的標簽IE6 bug,和一些定位寫法css js放置位置和原因...
閱讀 1884·2021-09-22 15:29
閱讀 3361·2019-08-30 15:44
閱讀 3570·2019-08-30 15:43
閱讀 1769·2019-08-30 13:48
閱讀 1497·2019-08-29 13:56
閱讀 2483·2019-08-29 12:12
閱讀 976·2019-08-26 11:35
閱讀 1059·2019-08-26 10:25