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

本文探讨了在React应用中使用Object.assign()进行状态更新的最佳实践,避免直接修改状态对象。同时,深入分析了在Redux中如何正确地更新store对象,包括添加和修改元素的具体方法。

使用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对象。

*注意:并不推荐使用此方法。因为redux只是记录数据状态,进行store修改操作,应该在state中操作比较规范; redux只进行数据记录,逻辑判断与修改放在模块state中,action则只进行异步请求处理


case
SELECTROLEPUSH: return state.set('selectedRoles', state.get('selectedRoles').filter(item => (item.role_id !== action.payload.role_id)).push(action.payload)) // 添加
     return state.set('selectedRoles', state.get('selectedRoles').filter(item => (item.role_id === action.payload))) // 修改
      
        return state.set('defInputVal', { ...state.get('defInputVal'), func_ids: action.payload })

 

转载于:https://www.cnblogs.com/litterjoan/p/10025426.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值