React.js綁定this的5種方法(小結(jié))
this在javascript中已經(jīng)相當(dāng)靈活,把它放到React中給我們的選擇就更加困惑了。下面一起來看看React this的5種綁定方法。
1.使用React.createClass
如果你使用的是React 15及以下的版本,你可能使用過React.createClass函數(shù)來創(chuàng)建一個組件。你在里面創(chuàng)建的所有函數(shù)的this將會自動綁定到組件上。
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)建一個組件,在其中給某個組件/元素一個onClick屬性,它現(xiàn)在并會自定綁定其this到當(dāng)前組件,解決這個問題的方法是在事件函數(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>
)
}
}
這種方法很簡單,可能是大多數(shù)初學(xué)開發(fā)者在遇到問題后采用的一種方式。然后由于組件每次執(zhí)行render將會重新分配函數(shù)這將會影響性能。特別是在你做了一些性能優(yōu)化之后,它會破壞PureComponent性能。不推薦使用
3.render方法中使用箭頭函數(shù)
這種方法使用了ES6的上下文綁定來讓this指向當(dāng)前組件,但是它同第2種存在著相同的性能問題,不推薦使用
class App extends React.Component {
handleClick() {
console.log('this > ', this);
}
render() {
return (
<div onClick={e => this.handleClick(e)}>test</div>
)
}
}
下面的方法可以避免這些麻煩,同時也沒有太多額外的麻煩。
4.構(gòu)造函數(shù)中bind
為了避免在render中綁定this引發(fā)可能的性能問題,我們可以在constructor中預(yù)先進行綁定。
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>
)
}
}
然后這種方法很明顯在可讀性和維護性上沒有第2種和第3種有優(yōu)勢,但是第2種和第3種由于存在潛在的性能問題不推薦使用,那么現(xiàn)在推薦 ECMA stage-2 所提供的箭頭函數(shù)綁定。
5.在定義階段使用箭頭函數(shù)綁定
要使用這個功能,需要在.babelrc種開啟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ù)會自動綁定到當(dāng)前組件的作用域種,不會被call改變
- 它避免了第2種和第3種的可能潛在的性能問題
- 它避免了第4種綁定時大量重復(fù)的代碼
總結(jié):
如果你使用ES6和React 16以上的版本,最佳實踐是使用第5種方法來綁定this
參考資料:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 一文全面解析JS中的this綁定規(guī)則
- JavaScript中this綁定規(guī)則你理解了嗎
- 細(xì)說JavaScript中的this指向與綁定規(guī)則
- JavaScript this綁定與this指向問題的解析
- JavaScript?中的?this?綁定規(guī)則詳解
- JavaScript中this的綁定你知道幾種?
- 詳解JavaScript中的this硬綁定
- 一文搞懂JavaScript中的this綁定規(guī)則
- JavaScript中?this?的綁定指向規(guī)則
- 詳解JavaScript的this指向和綁定
- JavaScript this綁定過程深入詳解
- JavaScript調(diào)用模式與this關(guān)鍵字綁定的關(guān)系
- 深入理解JavaScript this綁定規(guī)則
相關(guān)文章
React報錯Element type is invalid解決案例
這篇文章主要為大家介紹了React報錯Element type is invalid解決案例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
詳解使用webpack+electron+reactJs開發(fā)windows桌面應(yīng)用
這篇文章主要介紹了詳解使用webpack+electron+reactJs開發(fā)windows桌面應(yīng)用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02
React中不適當(dāng)?shù)腍ooks使用問題及解決方案
在 React 開發(fā)中,Hooks 提供了一種強大的方式來管理組件的狀態(tài)和生命周期,然而,不恰當(dāng)?shù)?nbsp;Hooks 使用可能會導(dǎo)致組件行為異常、性能問題或難以調(diào)試的錯誤,本文將探討 React 中常見的不適當(dāng) Hooks 使用問題,并提供解決方案,需要的朋友可以參考下2025-03-03
React使用Canvas繪制大數(shù)據(jù)表格的實例代碼
之前一直想用Canvas做表格渲染的,最近發(fā)現(xiàn)了一個很不錯的Canvas繪圖框架Leafer,api很友好就試著寫了一下,文中有詳細(xì)的代碼示例供大家參考,感興趣的小伙伴可以自己動手試試2023-09-09

