react setState()方法可以只修改一个对象的部分属性

Posted Gaochunling

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了react setState()方法可以只修改一个对象的部分属性相关的知识,希望对你有一定的参考价值。

使用Object.assign(),要注意不要返回原对象,应该返回一个新对象:

1、state 定义
state = {
  OAInfo: {app_name: ‘‘, user_id: ‘‘, app_login_id: ‘‘},
}
2、触发的修改方法:
thisOAval(event) {
  let data = Object.assign({}, this.state.OAInfo, { app_login_id: event.target.value })
  this.setState({
    OAInfo: data
  })
}

 

在redux中 修改store对象中同理,对已记录state属性进行 filter 循环查询,并替换对应元素后,整体赋值state对象。

case SELECTROLEPUSH: 
      return state.set(‘selectedRoles‘, state.get(‘selectedRoles‘).filter(item => (item.role_id !== action.payload.role_id)).push(action.payload))

 

以上是关于react setState()方法可以只修改一个对象的部分属性的主要内容,如果未能解决你的问题,请参考以下文章

React 组件中的state和setState

React 6/100 React原理 | setState | JSX语法转换 | 组件更新机制

前端知识 |浅谈React setState

React---之旅:巧妙引用传递,修改state

react学习笔记2之正确使用状态

react setState