react学习18-React 使用setState()更新类组件的state

setState分析

  • 修改数据是异步的
// setState更新数据是异步的
this.setState({
  num: this.state.num + 1
}, () => {
  // 该函数如果触发,那么就说明状态已经修改完成
  console.log(this.state.num)
})
  • 不要频繁调用setState
// 多次频繁调用setState,内部会进行合并,只更新最后一次
// 不要频繁调用setState方法
this.setState({
  num: this.state.num + 1
})
this.setState({
  num: this.state.num + 1
})
this.setState({
  num: this.state.num + 1
})

// setTimeout(() => {
//   console.log(this.state.num)
// }, 3000)
  • setState参数可以是一个函数
// setState另外一种调用形式
// 如下的写法支持多次调用
this.setState((state) => {
  // state表示上次完成更新后的结果
  return {
    num: state.num + 1
  }
})
this.setState((state) => {
  // state表示上次完成更新后的结果
  console.log(state.num)
  return {
    num: state.num + 1
  }
}, () => {
  console.log(this.state.num)
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值