欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React 事件綁定的實現及區(qū)別

 更新時間:2024年03月11日 09:34:48   作者:前端小超人rui  
事件綁定也是其中一部分內容,通過事件委托和事件合成,React 在內部對事件進行優(yōu)化和處理,減少了事件處理函數的調用次數,從而提升了性能,本文主要介紹了React事件綁定的實現及區(qū)別,感興趣的可以了解一下

1. 是什么

在react應用中,事件名都是小駝峰格式進行書寫,例如onclick要改寫成onClick最簡單的綁定事件如下:

class ShowAlert extends React.Component{
    ShowAlert(){
        console.log('hello')
    }
    render(){
        return <button onClick={this.ShowAlert}>show</button>
    }
}

從上面可以看到,事件綁定的方法需要使用{}包住上述代碼看似沒有問題,但是當前處理函數代碼或換成console.log(this)的時候,點擊按鈕,則會發(fā)現輸出undefined****

2. 如何綁定

為了解決上面正確輸出this問題,常見的綁定方式有:

  • render方法中使用bind
  • render方法中使用尖頭函數
  • constructor中bind
  • 定義階段使用箭頭函數綁定

2.1 render方法中使用bind

如果使用一個類組件,在其中給某個元素/組件 一個onClick屬性,他現在并會自定綁定其this到當前組件,解決這個問題的方法是在函數后使用.bind(this)將this綁定到當前組件中

class App extends React.Component{
    handleClick(){
        console.log(this)
    }
    render(){
        return <div onClick={this.handleClick.bind(this)}>test</div>
    }
}

這種渲染方式每次render渲染的時候,都會重新進行bind操作,影響性能

2.2 render方法中使用箭頭函數

通過ES6的上下文來將this的指向綁定給當前組件,同樣再每一次render的時候都會生成新的方法,影響性能

class App extends React.Component{
    handleClick(){
        console.log(this)
    }
    render(){
        return <div onClick={e=>this.handleClick.bind(e)}>test</div>
    }
}

2.3 constructor中bind

在constructor中預先綁定bind當前組件,可以避免render操作中重復綁定

class App extends React.Component{
    constructor(props){
      super(props);
      this.handleClick=this.handClick.bind(this);
    }
    handleClick(){
        console.log(this)
    }
    render(){
        return <div onClick={this.handleClick.bind(this)}>test</div>
    }
}

2.4 定義階段使用箭頭函數綁定(最優(yōu))

跟上述方式三一樣,能夠避免在render操作中重復綁定,實現也非常簡單,如下:

class App extends React.Component{
    constructor(props){
      super(props)
    }
    handleClick=()=>{
        console.log(this)
    }
    render(){
        return <div onClick={this.handleClick}>test</div>
    }
}

3. 區(qū)別

上述四種方法的方式,區(qū)別如下:

編寫方式:方式一方式二寫法簡單,方式三的編寫過于冗雜
性能方面:方式一和方式二在每次組件render的時候都會生成新的方法實例,性能問題欠缺。若該函數作為屬性值傳給子組件的時候,都會導致額外的渲染,而方式三方式四只會生成一個方法實例

綜上所述,方式四是最優(yōu)的事件綁定方式

到此這篇關于React 事件綁定的實現及區(qū)別的文章就介紹到這了,更多相關React 事件綁定內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 一百多行代碼實現react拖拽hooks

    一百多行代碼實現react拖拽hooks

    這篇文章主要介紹了一百多行代碼實現react拖拽hooks,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • React中useLayoutEffect鉤子使用場景詳解

    React中useLayoutEffect鉤子使用場景詳解

    這篇文章主要為大家介紹了React中useLayoutEffect鉤子使用場景詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • ReactNative實現的橫向滑動條效果

    ReactNative實現的橫向滑動條效果

    本文介紹了ReactNative實現的橫向滑動條效果,本文結合示例代碼給大家介紹的非常詳細,補充介紹了ReactNative基于寬度變化實現的動畫效果,感興趣的朋友跟隨小編一起看看吧
    2024-02-02
  • React Native實現簡單的登錄功能(推薦)

    React Native實現簡單的登錄功能(推薦)

    這篇文章主要介紹了React Native實現登錄功能的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • nodejs和react實現即時通訊簡易聊天室功能

    nodejs和react實現即時通訊簡易聊天室功能

    這篇文章主要介紹了nodejs和react實現即時通訊簡易聊天室功能,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • 在React中使用Antd上傳并讀取Excel文件的詳細步驟

    在React中使用Antd上傳并讀取Excel文件的詳細步驟

    在React中使用Antd組件庫來上傳并讀取Excel文件,可以結合antd的Upload組件和xlsx庫來實現,以下是一個詳細的步驟和示例代碼,展示如何在React應用中實現這一功能,感興趣的小伙伴跟著小編一起來看看吧
    2025-01-01
  • React和Vue組件更新的實現及區(qū)別

    React和Vue組件更新的實現及區(qū)別

    React 和 Vue 都是當今最流行的前端框架,它們都實現了組件化開發(fā)模式,本文將從React和Vue的組件更新原理入手,剖析兩者虛擬DOM difer算法的異同點,具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • React+Antd+Redux實現待辦事件的方法

    React+Antd+Redux實現待辦事件的方法

    這篇文章主要介紹了React+Antd+Redux實現待辦事件的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • React實現父組件調用子組件的兩種寫法

    React實現父組件調用子組件的兩種寫法

    react通信分很多種,比如:父子通信,兄弟通信等等,這里我們就簡單說一下父子通信,父子通信分為:父組件調用子組件里面的方法;子組件調用子組件里面的方法,這里我們著重說一下父組件調用子組件,需要的朋友可以參考下
    2024-04-04
  • React Native 環(huán)境搭建的教程

    React Native 環(huán)境搭建的教程

    本篇文章主要介紹了React Native 環(huán)境搭建的教程,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08

最新評論