问题导入
import React from 'react'
import ReactDOM from 'react-dom'
class App extends React.Component {
state = {
msg: 'hello react'
}
handleClick () {
console.log(this, '8888') // 这里的this是?
}
render () {
console.log(this, 'render里的this') // 这里的this是?
return (
<div>
<button onClick={this.handleClick}>点我</button>
</div>
)
}
}
ReactDOM.render(<App></App>, document.getElementById('root'))
-
render方法中的this指向的而是当前react组件。
-
事件处理程序中的this指向的是
undefined
分析原因
-
class的内部,开启了局部严格模式
use strict
,所以this不会指向windowundefined
-
onClick={this.fn}
中,this.fn的调用并不是通过类的实例调用的,所以值是undefined -
render函数是被组件实例调用的,因此render函数中的this指向当前组件
这样看的话可能不是很清楚我们换一种写法
知道了是this指向问题 大体解决方法如下
this指向解决方案
有三种方式
方式1 Function.prototype.bind(this)
class App extends React.Component {
state = {
msg: 'hello react'
}
handleClick() {
console.log(this.state.msg)
}
render() {
return (
<div>
<button onClick= {this.handleClick.bind(this)}>点我</button>
</div>
)
}
}
方式2 箭头函数
class App extends React.Component {
state = {
msg: 'hello react'
}
handleClick() {
console.log(this.state.msg)
}
render() {
return (
<div>
<button onClick={() => {this.handleClick()}}>点我</button>
</div>
)
}
}
缺点:1,需要额外包裹一个箭头函数,影响性能, 结构不美观
方式3:class 的实例方法【推荐】
class App extends React.Component {
state = {
msg: 'hello react'
}
handleClick = () => {
console.log(this.state.msg)
}
render() {
return (
<div>
<button onClick={this.handleClick}>点我</button>
</div>
)
}
}
注意:这个语法是试验性的语法,但是有babel的转义,所以没有任何问题
在实际开发中方式三使用最多 最方便 推荐使用
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。