cqwcns 发表于 2020-1-2 16:48

JS通过合并的方式修改对象的问题

本帖最后由 cqwcns 于 2020-1-6 12:28 编辑

JS中有个对象arrTest1,如下:
let arrTest1={series: [{
                                                type: 'bar',markLine: {data: [{type: 'average', name: '平均值'}]}
                                        }, {
                                                type: 'line(这个是我要修改的值)',markLine: {data: [{type: 'min', name: '最小'}]}
                                        }, {
                                                type: 'line',markLine: {data: [{type: 'max', name: '最大'}]}
                                        }]};
      
console.log(arrTest1.series.type);

我希望通过合并对象的方式(例如arrTest2合并到arrTest1),修改其中一个属性,请问arrTest2对象应该怎么写?
这样?{'series': [{},{'type': 'line'}]}

15774211127 发表于 2020-1-2 16:53

问题不出在arrTest2对象怎么写,而是js的Object.assign()不支持合并为对象类型的属性,他遇到对象类型的属性时是直接覆盖,所以需要自己写个深度合并方法来完成你说的功能
https://www.cnblogs.com/Man-Dream-Necessary/p/8780464.html

cqwcns 发表于 2020-1-2 17:01

15774211127 发表于 2020-1-2 16:53
问题不出在arrTest2对象怎么写,而是js的Object.assign()不支持合并为对象类型的属性,他遇到对象类型的属 ...

我是直接用在echarts的,echarts的setOption参数可以直接对重复的进行合并,不重复的不会影响。

15774211127 发表于 2020-1-2 17:06

cqwcns 发表于 2020-1-2 17:01
我是直接用在echarts的,echarts的setOption参数可以直接对重复的进行合并,不重复的不会影响。

那就是这样
let series = [{
                                                type: 'bar',markLine: {data: [{type: 'average', name: '平均值'}]}
                                        }, {
                                                type: 'line(这个是我要修改的值)',markLine: {data: [{type: 'min', name: '最小'}]}
                                        }, {
                                                type: 'line',markLine: {data: [{type: 'max', name: '最大'}]}
                                        }]
let arrTest1={series: series};
         
console.log(arrTest1.series.type);
series.type="(你要修改的值)"
let arrTest2 = {
    series: series
}

cqwcns 发表于 2020-1-6 09:32

15774211127 发表于 2020-1-2 16:53
问题不出在arrTest2对象怎么写,而是js的Object.assign()不支持合并为对象类型的属性,他遇到对象类型的属 ...

谢谢指教{:301_997:}
页: [1]
查看完整版本: JS通过合并的方式修改对象的问题