在學習React框架的時候,遇到個問題。一直不理解這里的.bind(this)中的this指代什么,我先上代碼
import React from 'react';
class Contacts extends React.Component {
constructor(props) {
super(props);
}
handleClick() {
console.log(this); // React Component instance
}
render() {
return (
<div onClick={this.handleClick.bind(this)}></div>
);
}
}
export default Contacts;
這里的 this.handleClick.bind(this) 最后這個this知道的就是 Contacts這個類嗎?
但是我看別的例子中的this介紹,比如下面這個
var foo={x:3}
var bar=function(){console.log(this.x)}
bar() //undefined
var boundFunc=bar.bind(foo);
boundFunc(); //3
這里的this是換了一個scope,那么我問題中問的this指代的就是 Contacts這個類嗎?
class A extends React.Component{
constructor(props) {
super(props);
}
handleClick() {
console.log(this);
}
render() {
return (
<div onClick={this.handleClick.bind(this)}></div>
);
}
}
class B extends React.Component{
handleClick() {
console.log("XXXX");
}
render() {
return (
<div onClick={this.handleClick.bind(A)}></div> //我這里這么寫是不是就可以把這里的socpe綁定到 class A環(huán)境里去了?可能語法有問題,或是實現(xiàn)不了,但是我就是借這個例子問一下bind()的用法
);
}
}
謝謝大神~~~~
class中默認是沒有this這個對象的,如果要在class中使用this,必須從父class中繼承。
讓class中有this,通過constructor實現(xiàn):
constructor() {
super(...arguments);
}
繼承后的this,要在function中實現(xiàn)呢,必須綁定到function中,有兩種辦法:
bind方法constructor() {
super(...arguments);
this.handleClick= this.handleClick.bind(this);
}
//call
<div onClick={this.handleClick}></div>
<div onClick={() => this.handleClick()} />
不建議你在事件引用的時候再綁定,而是在constructor方法中綁定。也是官方推薦方法。更方便的可以使用arrow function.
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產(chǎn)業(yè)為響應國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復興的升級產(chǎn)業(yè)鏈。利用北京大學優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓領(lǐng)域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。