数组并集以及promise

这篇博客探讨了如何处理数组的并集操作以及同步请求。`resolveAfter2Seconds`函数通过JSON获取数据并构建了一个不重复的代码集合。在成功处理AJAX请求后,`diff_arr_instead_before`函数用于比较并替换前数组中的重复元素,实现了数组的更新。博客重点展示了JavaScript中数组操作和异步处理的技巧。
摘要由CSDN通过智能技术生成

数组并集

resolveAfter2Seconds: function(data,code) {
    return new Promise(function(resolve, reject) {
    	$.getJSON(`./json`, function (res) {
            var data2 = res.navigations
            var tempKeys = [];
			for(var item of data){
			    if(tempKeys.indexOf(item['code']) == -1){
			        tempKeys.push(item['code']);
			    }
			} 
			for(var item of data2){
			    let sign = true;
			    for(var key of tempKeys){
			        if(key == item['code']){
			            sign = false;
			        }
			    }
			    if(sign) data.push(item);
			}
			console.log('after',data);
			resolve(data)
        });
    });
},

同步请求

// ajax 请求
success: async function(datas){		
    	//=====================================================================================
    	console.log('before',data);
    	var result = await functions.resolveAfter2Seconds(data,code);
    	//================================================================================ 	    	
},

替代前数组

 比较两个数组,后者替代前者重复元素
function diff_arr_instead_before(before,after,code){
	// 1. 把前者的提取键
	var tempKeys = [];
	for(var item of before){
	    if(tempKeys.indexOf(item[code]) == -1){
	        tempKeys.push(item[code]);
	    }
	} 
	var res = []    // 结果
	// 把后者的键取出来
	var afterTempKeys = [];   
	// 取到交集 后者那一部分
	for(var item of after){
	    let sign = false;
	    let compareKey = ''
	    // 遍历前者的键
	    for(var key of tempKeys){
	    	// 取后者的数据
	        if(key == item[code]){
	            sign = true;
	            compareKey = key;
	        } 
	    }
	    if(sign) {
	    	res.push(item);
	    	afterTempKeys.push(compareKey)
	    	console.log('=====新的========',item)
	    }
	}
	// 取前者的补集
	for(var i = 0; i< before.length;i++) {
	    let sign = false;
	    for(var key of afterTempKeys){
	        if(key == before[i][code]){
	            sign = true;
	        }
	    }
	    if(sign) {
	        console.log('======旧的=======',before[i][code])
	    	delete before[i]
	    }
	}
	
	var len = before.length;
	   for(var i = 0; i<len ;i++) {
	   	if(before[i] === undefined){
	   		before.splice(before[i],1)
	   	}
	}
	return res.concat(before)
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值