React.js綁定this的5種方法(小結(jié))
this在javascript中已經(jīng)相當(dāng)靈活,把它放到React中給我們的選擇就更加困惑了。下面一起來(lái)看看React this的5種綁定方法。
1.使用React.createClass
如果你使用的是React 15及以下的版本,你可能使用過(guò)React.createClass函數(shù)來(lái)創(chuàng)建一個(gè)組件。你在里面創(chuàng)建的所有函數(shù)的this將會(huì)自動(dòng)綁定到組件上。
const App = React.createClass({ handleClick() { console.log('this > ', this); // this 指向App組件本身 }, render() { return ( <div onClick={this.handleClick}>test</div> ); } });
但是需要注意隨著React 16版本的發(fā)布官方已經(jīng)將改方法從React中移除
2.render方法中使用bind
如果你使用React.Component創(chuàng)建一個(gè)組件,在其中給某個(gè)組件/元素一個(gè)onClick屬性,它現(xiàn)在并會(huì)自定綁定其this到當(dāng)前組件,解決這個(gè)問(wèn)題的方法是在事件函數(shù)后使用.bing(this)將this綁定到當(dāng)前組件中。
class App extends React.Component { handleClick() { console.log('this > ', this); } render() { return ( <div onClick={this.handleClick.bind(this)}>test</div> ) } }
這種方法很簡(jiǎn)單,可能是大多數(shù)初學(xué)開(kāi)發(fā)者在遇到問(wèn)題后采用的一種方式。然后由于組件每次執(zhí)行render將會(huì)重新分配函數(shù)這將會(huì)影響性能。特別是在你做了一些性能優(yōu)化之后,它會(huì)破壞PureComponent性能。不推薦使用
3.render方法中使用箭頭函數(shù)
這種方法使用了ES6的上下文綁定來(lái)讓this指向當(dāng)前組件,但是它同第2種存在著相同的性能問(wèn)題,不推薦使用
class App extends React.Component { handleClick() { console.log('this > ', this); } render() { return ( <div onClick={e => this.handleClick(e)}>test</div> ) } }
下面的方法可以避免這些麻煩,同時(shí)也沒(méi)有太多額外的麻煩。
4.構(gòu)造函數(shù)中bind
為了避免在render中綁定this引發(fā)可能的性能問(wèn)題,我們可以在constructor中預(yù)先進(jìn)行綁定。
class App extends React.Component { constructor(props) { super(props); this.handleClick = this.handleClick.bind(this); } handleClick() { console.log('this > ', this); } render() { return ( <div onClick={this.handleClick}>test</div> ) } }
然后這種方法很明顯在可讀性和維護(hù)性上沒(méi)有第2種和第3種有優(yōu)勢(shì),但是第2種和第3種由于存在潛在的性能問(wèn)題不推薦使用,那么現(xiàn)在推薦 ECMA stage-2 所提供的箭頭函數(shù)綁定。
5.在定義階段使用箭頭函數(shù)綁定
要使用這個(gè)功能,需要在.babelrc種開(kāi)啟stage-2功能,綁定方法如下:
class App extends React.Component { constructor(props) { super(props); } handleClick = () => { console.log('this > ', this); } render() { return ( <div onClick={this.handleClick}>test</div> ) } }
這種方法有很多優(yōu)化:
- 箭頭函數(shù)會(huì)自動(dòng)綁定到當(dāng)前組件的作用域種,不會(huì)被call改變
- 它避免了第2種和第3種的可能潛在的性能問(wèn)題
- 它避免了第4種綁定時(shí)大量重復(fù)的代碼
總結(jié):
如果你使用ES6和React 16以上的版本,最佳實(shí)踐是使用第5種方法來(lái)綁定this
參考資料:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解react、redux、react-redux之間的關(guān)系
這篇文章主要介紹了詳解react、redux、react-redux之間的關(guān)系,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04使用React實(shí)現(xiàn)輪播效果組件示例代碼
React剛出來(lái)不久,組件還比較少,不像jquery那樣已經(jīng)有很多現(xiàn)成的插件了,于是自己寫了一個(gè)基于React的輪播效果組件,現(xiàn)在分享給大家,有需要的可以參考借鑒。2016-09-09react16.8.0以上MobX在hook中的使用方法詳解
這篇文章主要為大家介紹了react16.8.0以上MobX在hook中的使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07React Hooks中模擬Vue生命周期函數(shù)的指南
React Hooks 提供了一種在函數(shù)組件中使用狀態(tài)和其他 React 特性的方式,而不需要編寫類組件,Vue 的生命周期函數(shù)和 React Hooks 之間有一定的對(duì)應(yīng)關(guān)系,本文給大家介紹了React Hooks中模擬Vue生命周期函數(shù)的指南,需要的朋友可以參考下2024-10-10前端開(kāi)發(fā)使用Ant Design項(xiàng)目評(píng)價(jià)
這篇文章主要為大家介紹了前端開(kāi)發(fā)使用Ant Design項(xiàng)目評(píng)價(jià),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08從零搭建Webpack5-react腳手架的實(shí)現(xiàn)步驟(附源碼)
本文主要介紹了從零搭建Webpack5-react腳手架的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08