https://blog.csdn.net/qq_26222859/article/details/70331833
var json1 = [
{"guoshui":[
300000, 500000, 600000, 800000, 1000000, 1200000, 1400000, 1600000, 1800000, 1600000, 1400000, 1200000
]},
{"dishui":[
1100000, 1200100, 1300000, 1100000, 1050000, 1400000, 1200000, 1600000, 1800000, 1200000, 1400000, 1100000
]},
{"heji":[
400000, 1300000, 1200000, 1100000, 1500000, 1400000, 1200000, 1600000, 1700000, 1100000, 1400000, 1400000
]}
]
有如下對象:
現在希望把他整合進數組里,形成如下數組:
[{
name: '國稅',
type: 'bar',
data: [300000, 500000, 600000, 800000, 1000000, 1200000,1400000,1600000,1800000,1600000,1400000,1200000],
markPoint : {
data : [
{type : 'max', name: '最大值'},
{type : 'min', name: '最小值'}
]
},
markLine : {
data : [
{type : 'average', name: '平均值'}
]
}
},
{
name: '地稅',
type: 'bar',
data: [1100000, 1200100, 1300000, 1100000, 1050000, 1400000,1200000,1600000,1800000,1200000,1400000,1100000],
markPoint : {
data : [
{type : 'max', name: '最大值'},
{type : 'min', name: '最小值'}
]
},
markLine : {
data : [
{type : 'average', name: '平均值'}
]
}
},
{
name: '合計',
type: 'bar',
data: [400000, 1300000, 1200000, 1100000, 1500000, 1400000,1200000,1600000,1700000,1100000,1400000,1400000],
markPoint : {
data : [
{type : 'max', name: '最大值'},
{type : 'min', name: '最小值'}
]
},
markLine : {
data : [
{type : 'average', name: '平均值'}
]
}
},
]
在JavaScript中,數組其實一個對象,或者說是一種擁有類數組特性的對象。
它把數組的下標轉變為字符串,用其作為屬性。如果用typeof判斷一個數組,得出的
結果是object。數組的第一個值自動獲得屬性名‘0’,第二個值自動獲得屬性名‘1’,以此類推。
關於JavaScript的數組和對象,我先說說他們的區別:
對象是自動擴容的,通過".屬性名"可以動態添加對象的屬性。
因為數組是對象,所以也是自動擴容的,通過".屬性名"或者[屬性名]或者push()可以動態添加對象的屬性。
對象遍歷的方式是for ..in..隨機訪問,用屬性名作為遍歷的key 數組遍歷的方式是用for循環順序訪問,可以直接用i++作為遍歷的key。不建議用for ..in..隨機訪問
回到之前個問題
JavaScript把對象里的數據整合進另外一個數組里要涉及到數組的擴容,以及對象和數組的遍歷。
所以寫法如下:
var array1=[{
name: '國稅',
type: 'bar',
markPoint : {
data : [
{type : 'max', name: '最大值'},
{type : 'min', name: '最小值'}
]
},
markLine : {
data : [
{type : 'average', name: '平均值'}
]
}},
{name: '地稅',
type: 'bar',
markPoint : {
data : [
{type : 'max', name: '最大值'},
{type : 'min', name: '最小值'}
]
},
markLine : {
data : [
{type : 'average', name: '平均值'}
]
}},
{
name: '合計',
type: 'bar',
markPoint : {
data : [
{type : 'max', name: '最大值'},
{type : 'min', name: '最小值'}
]
},
markLine : {
data : [
{type : 'average', name: '平均值'}
]
}
}];
//array1[0].data=json1['guoshui'];
//array1[1].data=json1['dishui'];
//array1[2].data=json1['heji'];
var i=0;
for(item in json1){
array1[i++].data=json1[item];
}
//console.log(json1[item]);
//array[item]=json1[item];
console.log(array1);
