js 对象型数组去重

方法一:用reduce

	var arr = [
        {name:'uzi',color:'blue'},
        {name:'pdd',color:'white'},
        {name:'mlxg',color:'orange'},
        {name:'uzi',color:'red'},
    ]

    let hash = {};
    var newArr = arr.reduce((prev, next) => {
        hash[next.name] ? '' : hash[next.name] = true && prev.push(next);
        return prev
    }, []);

推荐: new Map

const uniqueArr = [...new Map(arr.map((item) => [item.id, item])).values()]

单数组去重

const arr = [1, 2, 2, 3, 4, 4];
const uniqueArr = Array.from(new Set(arr));
console.log(uniqueArr); // [1, 2, 3, 4]

方法二:for循环

	var arr = [
	    {id: 1, name: 'sli', year: 2012},
	    {id: 2, name: 'ap', year: 2015},
	    {id: 1, name: 'alslion', year: 2012},
	    {id: 3, name: 'pose', year: 2012},
	]
	
	// 删除arr中的重复对象
	var newArr= [];
	var arrId = [];
	for(var item of arr){
	    if(arrId.indexOf(item['id']) == -1){
	        arrId.push(item['id']);
	        newArr.push(item);
	    }
	}

2、数组对象完全相同的去除

	function delObj(obj) {
        var uniques = [];
        var stringify = {};
        for (var i = 0; i < obj.length; i++) {
            var keys = Object.keys(obj[i]);
            keys.sort(function(a, b) {
                return (Number(a) - Number(b));
            });
            
            var str = '';
            for (var j = 0; j < keys.length; j++) {
                str += JSON.stringify(keys[j]);
                str += JSON.stringify(obj[i][keys[j]]);
            }
            
            if (!stringify.hasOwnProperty(str)) {
                uniques.push(obj[i]);
                stringify[str] = true;
            }
        }
        uniques = uniques;
        return uniques;
    }
    var arr = [
        {name:'uzi',color:'blue'},
        {name:'pdd',color:'white'},
        {name:'mlxg',color:'orange'},
        {name:'uzi',color:'blue'}
    ]
    delObj(arr)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值