React中this指向问题

问题导入

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不会指向window undefined

  • onClick={this.fn}中,this.fn的调用并不是通过类的实例调用的,所以值是undefined

  • render函数是被组件实例调用的,因此render函数中的this指向当前组件

这样看的话可能不是很清楚我们换一种写法

 非严格模式 一般都是挂在window上的 claa内部是默认开启了严格模式 而严格模式中 由于相对于没有被谁调用所以值是undefined

知道了是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的转义,所以没有任何问题

在实际开发中方式三使用最多 最方便 推荐使用

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值