在react中通过state
以及setState()
来控制组件的状态。
state
state
是 react 中用来存储组件数据状态的,可以类比成 vue 中的 data。
setState()
与 vue 中不同的是 state
不能直接被修改,需要通过 setState()
的方法去修改。
setState()
更新组件状态之后不会立即生效,react 为提高性能会按批次更新 state 然后 render, 即异步操作,所以setSate()
之后立即去取state的值并不是更新之后的状态。setState()
第一个参数接受两种类型的参数,Object以及Function- Object
当参数是Object的时候, 可以即为对应 state 中的 key, value 即是新的值。this.setState({ msg: '更新state msg' })
- Function
当参数是函数的时候,setState()
会将上一个setState()
的结果作为参数传入这个函数... constructor () { this.state = { counter: 0 } } add() { this.setState({ counter: this.state.counter + 1 }) this.setState({ counter: this.state.counter + 1 }) // 此时`this.state.counter`的值还是初始值0,,所以这个操作是无效的 this.setState(prevState => { counter: prevState.counter + 1 }) // `prevState.counter` 为上次更新之后的值,即是1 } ...
- Object
setState()
第二个参数是一个回调函数,表示 state 更新完成
根据这个可以使用Promise以及async/await,封装成同步操作this.setState({ msg: '更新state msg' }, () => { console.log('state 更新完毕') })
setStateAsync(state) { return new Promise(resolve => { this.setState(state, resolve) }) } // 使用 async add() { await setStateAsync({ counter: this.state.counter + 1 }) console.log('state 更新完毕') }