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

深入理解React中es6創(chuàng)建組件this的方法

 更新時間:2016年08月29日 09:28:22   作者:Mingjie_Zhang  
this的本質(zhì)可以這樣說,this跟作用域無關(guān)的,只跟執(zhí)行上下文有關(guān)。接下來通過本文給大家介紹React中es6創(chuàng)建組件this的方法,非常不錯,感興趣的朋友一起看看吧

首發(fā)于:https://mingjiezhang.github.io/。

在JavaScript中,this對象是運行時基于函數(shù)的執(zhí)行環(huán)境(也就是上下文)綁定的。

從react中的demo說起

Facebook最近一次更新react時,將es6中的class加入了組件的創(chuàng)建方式當中。Facebook也推薦組件創(chuàng)建使用通過定義一個繼承自 React.Component 的class來定義一個組件類。官方的demo:

class LikeButton extends React.Component {
constructor() {
super();
this.state = {
liked: false
};
this.handleClick = this.handleClick.bind(this);
}
handleClick() {
this.setState({liked: !this.state.liked});
}
render() {
const text = this.state.liked ? 'liked' : 'haven\'t liked';
return (
<div onClick={this.handleClick}>
You {text} this. Click to toggle.
</div>
);
}
}
ReactDOM.render(
<LikeButton />,
document.getElementById('example')
);

上面的demo中有大量this的使用,在 class LikeButton extends React.Component 中我們是聲明該class,因為this具體是由其上下文決定的,因此在類定義中我們無法得知this用法。 相當于是new了上面定義的類,首先調(diào)用 constructor() 函數(shù), this.state 的this上下文就是該實例對象;同理,render() 函數(shù)中 this.state.liked 的this上下文也是該對象。問題在于 onClick={this.handleClick} ,獲取該函數(shù)引用是沒有問題,這里的this上下文就是該對象。

這時問題來了,在原來 React.createClass 中, handleClick() 在onClick事件觸發(fā)的時候,會自動綁定到LikeButton實例上,這時候該函數(shù)的this的上下文就是該實例。不過在ES6的class的寫法中,F(xiàn)acebook取消了自動綁定,實例化LikeButton后,handleClick()的上下文是div的支撐實例( backing instance ),而 handleClick() 原本要綁定的上下文是LikeButton的實例。對于該問題,我們有多種解決方案。

使用bind()函數(shù)改變this的上下文

可以在class聲明中的constructor()函數(shù)中,使用

this.handleClick = this.handleClick.bind(this);

該方法是一個bind()綁定,多次使用。在該方法中,我們在聲明該實例后,可以在該實例任何地方使用 handleClick() 函數(shù),并且該 handleClick() 函數(shù)的this的上下文都是LikeButton實例對象。

除此我們也可以在具體使用該函數(shù)的地方綁定this的上下文到LikeButton實例對象,代碼如下

<div onClick={this.handleClick.bind(this)}>
You {text} this. Click to toggle.
</div>

這種方法需要我們每次使用bind()函數(shù)綁定到組件對象上。

es6的箭頭函數(shù)

es6中新加入了箭頭函數(shù)=>,箭頭函數(shù)除了方便之外還有而一個特征就是將函數(shù)的this綁定到其定義時所在的上下文。這個特征也可以幫助我們解決這個問題。使用如下代碼:

<div onClick={() => this.handleClick()}>
You {text} this. Click to toggle.
</div>

這樣該 this.handleClick() 的上下文就會被綁定到LikeButton的實例對象上。個人認為,使用箭頭函數(shù)使得JavaScript更加接近面向?qū)ο蟮木幊田L(fēng)格。

this的總結(jié)

this的本質(zhì)就是:this跟作用域無關(guān)的,只跟執(zhí)行上下文有關(guān)。

以上所述是小編給大家介紹的React中es6創(chuàng)建組件this的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • React創(chuàng)建組件的三種方式及其區(qū)別是什么

    React創(chuàng)建組件的三種方式及其區(qū)別是什么

    在React中,創(chuàng)建組件的三種主要方式是函數(shù)式組件、類組件和使用React Hooks的函數(shù)式組件,本文就詳細的介紹一下如何使用,感興趣的可以了解一下
    2023-08-08
  • 詳解Ant Design of React的安裝和使用方法

    詳解Ant Design of React的安裝和使用方法

    這篇文章主要介紹了詳解Ant Design of React的安裝和使用方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • 通過React-Native實現(xiàn)自定義橫向滑動進度條的 ScrollView組件

    通過React-Native實現(xiàn)自定義橫向滑動進度條的 ScrollView組件

    開發(fā)一個首頁擺放菜單入口的ScrollView可滑動組件,允許自定義橫向滑動進度條,且內(nèi)部渲染的菜單內(nèi)容支持自定義展示的行數(shù)和列數(shù),在內(nèi)容超出屏幕后,渲染順序為縱向由上至下依次排列,對React Native橫向滑動進度條相關(guān)知識感興趣的朋友一起看看吧
    2024-02-02
  • React+ts實現(xiàn)二級聯(lián)動效果

    React+ts實現(xiàn)二級聯(lián)動效果

    這篇文章主要為大家詳細介紹了React+ts實現(xiàn)二級聯(lián)動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • React系列useSyncExternalStore學(xué)習(xí)詳解

    React系列useSyncExternalStore學(xué)習(xí)詳解

    這篇文章主要為大家介紹了React系列useSyncExternalStore的學(xué)習(xí)及示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • React useState超詳細講解用法

    React useState超詳細講解用法

    我正在處理的組件是表單的時間輸入。表單相對復(fù)雜,并且是動態(tài)生成的,根據(jù)嵌套在其他數(shù)據(jù)中的數(shù)據(jù)顯示不同的字段。我正在用useReducer管理表單的狀態(tài),到目前為止效果很好
    2022-11-11
  • React+echarts?(echarts-for-react)?實現(xiàn)中國地圖及省份切換功能

    React+echarts?(echarts-for-react)?實現(xiàn)中國地圖及省份切換功能

    這篇文章主要介紹了React+echarts?(echarts-for-react)?畫中國地圖及省份切換,有足夠的地圖數(shù)據(jù),可以點擊到街道,示例我只出到市級,本文結(jié)合實例代碼給大家介紹的非常詳細需要的朋友可以參考下
    2022-11-11
  • React組件通信淺析

    React組件通信淺析

    這篇文章主要介紹了React組件通信,在開發(fā)中組件通信是React中的一個重要的知識點,本文通過實例代碼給大家講解react中常用的父子、跨組件通信的方法,需要的朋友可以參考下
    2022-12-12
  • React組件中使用JSON數(shù)據(jù)文件的方法詳解

    React組件中使用JSON數(shù)據(jù)文件的方法詳解

    要在 React 組件中使用 JSON 數(shù)據(jù),有多種方法,這篇文章主要為大家詳細介紹了五個常見的方法,文中的示例代碼講解詳細,有需要的小伙伴可以了解下
    2024-01-01
  • 詳解react應(yīng)用中的DOM DIFF算法

    詳解react應(yīng)用中的DOM DIFF算法

    這篇文章主要介紹了react應(yīng)用中的DOM DIFF算法,幫助大家更好的理解和學(xué)習(xí)使用react,感興趣的朋友可以了解下
    2021-04-04

最新評論