JS数组去重精简版

看了很多人写的好几个去重方法,我在这里精简组合下,适用于已排序与未排序的数组。

废话不多说,上代码。

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>数组去重</title>
    </head>
    <body>
        
        <script>
            
            /**
             * @param {Object} array    需要去重的数组
             * @param {Object} isSorted    是否已经排过序
             */
            function unique(array,isSorted){
                var res = [],val;
                for(var i = 0,len = array.length;i < len;i++){
                    var value = array[i];
                    if(isSorted){            //如果排过序,比较相邻的,第一个不需要比较
                        if(!i || val !== value){
                            res.push(value);
                        }
                        val = value;
                    }else if(res.indexOf(value) === -1){    //如果没排过序,比较临时数组中是否存在
                        res.push(value);
                    }
                }
                return res;
            }
            
            var array1 = [1,2,'1',2,1];
            var array2 = [1,1,2,2,'1'];
            
            console.log(unique(array1));
            console.log(unique(array2,true));
            
        </script>
    </body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值