0

我的状态对象如下所示:

const [result,setResult] = useState({
  series: [
      {
          name: 'Budget',
          data: [5000, 3000, 5000, 7000, 6000, 4000]
      },
      {
          name: 'Income',
          data: [8000, 1000, 7000, 2000, 5000, 3000]
      }
  ]
})

现在我想将一些数据附加到第一个对象的data数组中series

{
   name: 'Budget',
   data: [5000, 3000, 5000, 7000, 6000, 4000]
}

我尝试这样做:

function addNumber(){
  setResult([...result.series[0].data,45]) 
}

但它不起作用。有什么建议或解决方案吗?

4

1 回答 1

0

最好使用不可变 js 来更新嵌套数据,您可以使用 immutableJs 这样做:

setResult(immutable.setIn(result, ['series', 0, 'data'], result.series[0].data.concat(45)))

或者

setResult(immutable.updateIn(result, ['series', 0, 'data'], array => array.concat(45)))

指向不可变 js 文档的链接 https://immutable-js.github.io/immutable-js/docs/#/

于 2020-04-10T16:13:15.007 回答