React-修改状态

  • Post author:
  • Post category:其他


在 React 中不能直接修改组件的状态,需要通过

setState()

来进行修改

语法:

setState(updater[, callback])

  • updater

    更新器

  • callback

    更新后执行的回调函数



修改状态

比如想要将 state 中的 content 值修改为 ‘香香’

state = {
  content: '大熊'
}

通过直接修改的方式并不能触发视图的更新:

this.state.content = '香香'

需要通过 setState 来进行修改:

this.setState({
  content: '香香'
})



获取最新的状态值

因为

setState()

是异步的,所以在修改状态后不一定能获取到最新的值,如果想要获取最新的状态值可以为

setState()

提供一个回调函数,在状态更新后会去执行这个回调,可以在回调函数中获取最新的状态

示例:

this.setState({
  content: '香香'
}, () => {
  // 通回调获取最新的状态
  console.log(this.state.content)
})


setState()

的第一个参数也可以是函数,这个函数接收两个参数:第一个参数为更新前的状态值,第二个参数为

props

(可获取父级组件传递的数据);当修改状态时涉及到前一个状态值时就可以使用这种形式。

this.setState((state, props) => {
  console.log(state.content, props)
  // 返回一个对象
  return {
    content: prev.content + '香香'
  }
})



版权声明:本文为weixin_44486539原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。