本文实例讲述了JavaScript实现构造json数组的方法。分享给大家供大家参考,具体如下:

从后端拿到的数据是一个数组,每个元素中包含的数据如下(host相同的记录都是相邻的)


currentTime:“1470729601”
host:“10.3.34.21”
taskList:null
taskNum:1


想构造类似如下结构的json数组

[{
name: 'host:10.1.6.49',
data: [
[1470641461000, 5],
[1470642581000, 4],
[1470643701000, 2],
[1470647341000, 3]
]
}, {
name: 'host:10.3.34.18',
data: [
[1470641461000, 2],
[1470642581000, 2],
[1470643701000, 1],
[1470647341000, 4]
]
}, {
name: 'host:10.2.2.22',
data: [
[1470641461000, 3],
[1470642581000, 2],
[1470643701000, 6],
[1470647341000, 4]
]
},{
name: 'host:10.1.110.96',
data: [
[1470641461000, 1],
[1470642581000, 8],
[1470643701000, 1],
[1470647341000, 1]
]
},{
name: 'host:10.2.2.87',
data: [
[1470641461000, 7],
[1470642581000, 3],
[1470643701000, 6],
[1470647341000, 5]
]
}]

错误的方式:

var backendData = data.result;
var resultList = new Array();
var curHost = "";
var oneHostDataList = new Array();
for (var i in backendData) {
var host = backendData[i].host;
if (host != curHost) {
if(i != 0) {
var item = new Object();
item.name = curHost;
item.data = oneHostDataList;
resultList.push(item);
}
oneHostDataList = new Array();
curHost = host;
}
else {
var dot = new Array();
dot.push(backendData[i].currentTime * 1000);
dot.push(backendData[i].taskNum);
oneHostDataList.push(dot);
}
}
var item = new Object();
item.name = curHost;
item.data = oneHostDataList;
resultList.push(item);
$scope.data = JSON.stringify(resultList);

以上方式的问题在于转换后会使得name和host和带上引号,正确的方式如下:

var backendData = data.result;
var resultList = [];
var curHost = "";
var oneHostDataList = new Array();
for (var i in backendData) {
var host = backendData[i].host;
if (host != curHost) {
if(i != 0) {
var item = {
name: curHost,
data: oneHostDataList
};
resultList.push(item);
}
oneHostDataList = new Array();
curHost = host;
}
else {
var dot = new Array();
dot.push(backendData[i].currentTime * 1000);
dot.push(backendData[i].taskNum);
oneHostDataList.push(dot);
}
}
var item = new Object();
item.name = curHost;
item.data = oneHostDataList;
resultList.push(item);
$scope.data = resultList;

最后

为了帮助大家让学习变得轻松、高效,给大家免费分享一大批资料,帮助大家在成为全栈工程师,乃至架构师的路上披荆斩棘。在这里给大家推荐一个前端全栈学习交流圈:​866109386​.欢迎大家进群交流讨论,学习交流,共同进步。

当真正开始学习的时候难免不知道从哪入手,导致效率低下影响继续学习的信心。

但最重要的是不知道哪些技术需要重点掌握,学习时频繁踩坑,最终浪费大量时间,所以有有效资源还是很有必要的。

最后祝福所有遇到瓶疾且不知道怎么办的前端程序员们,祝福大家在往后的工作与面试中一切顺利。