var hasInfoNodes=scope.nodedata=splitDatas.filter(function(element,index,array) { return ([7,13,17,23,30].indexOf(parseInt(element.nodeIndex)) > -1); });如代码,是从数组splitDatas中过滤出来我想要的几个对象,这里根据对象的nodexIndex 获取,[7,13,17,23,30],只要包含这个nodexIndex,就放进hasInfoNodes中。现在问题来了,但是splitDatas中不一定完全有7,13,17,23,30这几个,那么,我该如何设置,当splitDatas中没有某个对象时候,比如,没有13,30设置其为{nodeIndex:"13",nodeStatus:"0"}{nodeIndex:"30",nodeStatus:"0"}放进hasInfoNodes里面。而且最终要按照nodeIndex的大小排列好hasInfoNodes的对象呢,也就是,最终一定有[7,13,17,23,30]这个几个对象,这里面的数字就是对象的nodeIndex
1 回答
MMTTMM
TA贡献1869条经验 获得超4个赞
问题简单来说就是在splitDatas里面找和自定义数组arr[7,13,17,23,30]的交集,如果splitDatas没有的则使用arr进行填充。
所以我用arr来循环,然后找和splitDatas的交集,如果没有,则使用arr的值来填充,简单的说:求交集,给交集补数据。
//测试数据var splitDatas = [
{ nodeIndex: "7", nodeStatus: "2" },
{ nodeIndex: "13", nodeStatus: "2" },
{ nodeIndex: "30", nodeStatus: "1" }
];var hasInfoNodes = [13, 7, 23, 17, 30].map(function (value, i) { //两数组相交索引
var index = -1; //在splitDatas中寻找arr当前项
if (splitDatas.some(function (element, i) { if (+element.nodeIndex == value) { //找到了索引
index = i; return true;
}
})) { //
return splitDatas[index];
} //数据格式统一
return { nodeIndex: value + '', nodeStatus: "0" };
});
hasInfoNodes.sort(function (a, b) { return a.nodeIndex - b.nodeIndex;
});代码还有更多优化的空间,大体思路如此。
想了下换了一种思路做,先找到arr和splitDatas的差集temp,然后把temp的格式和splitDatas对齐(转换成一致),再把temp和splitDatas连接,最终排序即可,简单的说:求差集,给差集补数据。
//测试数据var splitDatas = [
{ nodeIndex: "7", nodeStatus: "2" },
{ nodeIndex: "13", nodeStatus: "2" },
{ nodeIndex: "30", nodeStatus: "1" }
];var arr = [13, 7, 23, 17, 30];//求出差集var temp = arr.filter(function (value) { return !~splitDatas.findIndex(function (element) {//Array.prototype.findIndex from in ES2015
return value == +element.nodeIndex;
});
});var hasInfoNodes = temp.map(function (value) { //把差集的格式转换成splitDatas一致的格式
return { nodeIndex: value + '', nodeStatus: "0" };
}).concat(splitDatas);//两个数组连接//排序hasInfoNodes.sort(function (a, b) { return a.nodeIndex - b.nodeIndex;
});添加回答
举报
0/150
提交
取消
