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

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

 更新時(shí)間:2018年06月05日 14:39:47   作者:Monster000  
this在javascript中已經(jīng)相當(dāng)靈活,這篇文章主要介紹了React.js綁定this的5種方法(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

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)化:

  1. 箭頭函數(shù)會(huì)自動(dòng)綁定到當(dāng)前組件的作用域種,不會(huì)被call改變
  2. 它避免了第2種和第3種的可能潛在的性能問(wèn)題
  3. 它避免了第4種綁定時(shí)大量重復(fù)的代碼

總結(jié):

如果你使用ES6和React 16以上的版本,最佳實(shí)踐是使用第5種方法來(lái)綁定this

參考資料:

React.js pure render性能渲染反模式

this綁定裝飾器

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解react、redux、react-redux之間的關(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中直接使用Redux

    如何在React中直接使用Redux

    這篇文章主要介紹了如何在React中直接使用Redux,目前redux在react中使用是最多的,所以我們需要將之前編寫的redux代碼,融入到react當(dāng)中去,本文給大家詳細(xì)講解,需要的朋友可以參考下
    2022-11-11
  • 使用React實(shí)現(xiàn)輪播效果組件示例代碼

    使用React實(shí)現(xiàn)輪播效果組件示例代碼

    React剛出來(lái)不久,組件還比較少,不像jquery那樣已經(jīng)有很多現(xiàn)成的插件了,于是自己寫了一個(gè)基于React的輪播效果組件,現(xiàn)在分享給大家,有需要的可以參考借鑒。
    2016-09-09
  • react16.8.0以上MobX在hook中的使用方法詳解

    react16.8.0以上MobX在hook中的使用方法詳解

    這篇文章主要為大家介紹了react16.8.0以上MobX在hook中的使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • react源碼層探究setState作用

    react源碼層探究setState作用

    寫react的時(shí)候,踩了幾次坑發(fā)現(xiàn)setstate之后state不會(huì)立刻更新,于是判定setstate就是異步的方法,但是直到有一天,我想立刻拿到更新的state去傳參另一個(gè)方法的時(shí)候,才問(wèn)自己,為什么setstate是異步的?準(zhǔn)確地說(shuō),在React內(nèi)部機(jī)制能檢測(cè)到的地方,setState就是異步的
    2022-10-10
  • 淺談react-router@4.0 使用方法和源碼分析

    淺談react-router@4.0 使用方法和源碼分析

    這篇文章主要介紹了淺談react-router@4.0 使用方法和源碼分析,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-06-06
  • React Hooks中模擬Vue生命周期函數(shù)的指南

    React 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
  • 基于React編寫一個(gè)全局Toast的示例代碼

    基于React編寫一個(gè)全局Toast的示例代碼

    前些日子在做項(xiàng)目的時(shí)候,需要封裝一個(gè)Toast組件,我想起之前用過(guò)的庫(kù),只要在入口文件中引入就可以在全局中使用,還是很方便的,借這次機(jī)會(huì)也來(lái)實(shí)現(xiàn)一下,所以本文介紹了React中如何編寫一個(gè)全局Toast,需要的朋友可以參考下
    2024-05-05
  • 前端開(kāi)發(fā)使用Ant Design項(xiàng)目評(píng)價(jià)

    前端開(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)步驟(附源碼)

    本文主要介紹了從零搭建Webpack5-react腳手架的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08

最新評(píng)論