React-事件绑定

类组件里的方法

两种调用

    <button onClick={()=>{ this.changeWether()}}>修改</button>
		// 1. 本质是在点击的时候,再来找this 调用,这个this肯定是指向实例对象的
    <button onClick={this.changeWether.bind(this)}>修改</button>
		// 2. 本质是 用bind修改this,render里的this 也是指向实例对象的,所以通过bind的方法修改this但是并不调用函数

// 错误示范
 <button onClick={this.changeWether}></button>
// 这个调用的时候,this函数的this,虽然是类里的函数,但是还是指向undefined

// 3. 或者直接在函数定义的时候
    changeWether = ()=>{
      console.log(this)
      const isHot = this.state.isHot
      this.setState({
        isHot: !isHot
      })
    }
// 这样就可以直接使用  
 <button onClick={this.changeWether}></button>

setState方法

      this.setState({
        "isHot":!this.state.isHot
      })
		// 直接修改state里的字段 isHot
		// 并且是合并,不是替换,修改不一样的,一样的不变
		// 每次修改状态,render都会调用一次

      const isHot = this.state.isHot
      this.setState({
        isHot: !isHot
      })
		// 也可用保存到一个变量的形式来修改
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值