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中使用Antd上傳并讀取Excel文件的詳細步驟
在React中使用Antd組件庫來上傳并讀取Excel文件,可以結合antd的Upload組件和xlsx庫來實現,以下是一個詳細的步驟和示例代碼,展示如何在React應用中實現這一功能,感興趣的小伙伴跟著小編一起來看看吧2025-01-01