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>

 

posted @ 2019-06-17 08:49  半瓶假酒  阅读(210)  评论(0编辑  收藏  举报