js数组处理,拼接

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


小怪兽爱吃肉
浏览 483回答 1
1回答

MMTTMM

问题简单来说就是在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; });
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript