国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

React.js綁定this的5種方法(小結(jié))

2024-05-06 15:33:39
字體:
供稿:網(wǎng)友

this在javascript中已經(jī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到當前組件,解決這個問題的方法是在事件函數(shù)后使用.bing(this)將this綁定到當前組件中。

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

這種方法很簡單,可能是大多數(shù)初學開發(fā)者在遇到問題后采用的一種方式。然后由于組件每次執(zhí)行render將會重新分配函數(shù)這將會影響性能。特別是在你做了一些性能優(yōu)化之后,它會破壞PureComponent性能。不推薦使用

3.render方法中使用箭頭函數(shù)

這種方法使用了ES6的上下文綁定來讓this指向當前組件,但是它同第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中預先進行綁定。

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>  ) }}            
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 南华县| 丰宁| 洪雅县| 南宫市| 砀山县| 化州市| 合山市| 冷水江市| 全南县| 探索| 威信县| 镇沅| 鹤峰县| 泉州市| 敖汉旗| 和静县| 民权县| 融水| 和田市| 自贡市| 吉林市| 玉屏| 巴林右旗| 津南区| 松溪县| 陆川县| 武定县| 福鼎市| 会昌县| 东阳市| 长春市| 边坝县| 博爱县| 海兴县| 越西县| 和静县| 青川县| 和静县| 澄城县| 辽阳市| 大城县|