javascript之数组去重

栏目: JavaScript · 发布时间: 6年前

内容简介:平时工作当中经常会遇到数组去重的需求,所以在这里整理一下有哪些方法可以实现数组的去重。

  平时工作当中经常会遇到数组去重的需求,所以在这里整理一下有哪些方法可以实现数组的去重。

1、双层for循环

function removeSameEle(arr){
        let res=[]; 
        for(var i=0,len=arr.length;i<len;i++){
            for(var j=0,resLen=res.length;j<resLen;j++){
                if(arr[i]===arr[j]){//判断结果中是否已存在该数据了
                    break;
                }
            }
            //判断是否执行到了res的末尾
            if(j===resLen){
                arr.push(arr[i]);
            }
        }
        return res;
    }
复制代码

2、indexof或者includes

function removeSameEle(arr){
        let res=[];
        for(var i=0,len=arr.length;i<len;i++){
            //if(!res.includes(arr[i])){
            if(res.indexof(arr[i])<0){//判断结果中是否存在该数据了
                res.push(arr[i])
            }
        }
        return res;
    }
复制代码

3、filter

function removeSameEle(arr){
        let res=arr.filter((item,index,arr)=>{
            return arr.indexOf(item)===index;
        });
        return res;
    }
复制代码

4、set唯一值去重

  此方法只能用于对简单数组进行去重。
function removeSameEle(arr){
        let res=new Set(arr);
        return [...res];
    }
复制代码

5、sort排序后去重

function removeSameEle(arr){
        let res=[];
        let sortedArr=arr.sort();
        for(let i=0,len<sortedArr.length;i<len-1;i++){
            if(i==0||sortedArr[i]!==sortedArr[i+1]){
                res.push(sortedArr[i]);
                 if(i===(len-2)){
                    res.push(sortedArr[i+1]);
                }
            }
        }
        return res;
    }
复制代码

6、使用object.keys()去重

function removeSameEle(arr){
        let res=[];
        let obj={};
        arr.forEach((item,index)=>{
            if(!obj[item]){
                obj[item]=item
            }
        });
        for(let value of Object.values(obj)){
            res.push(value);
        }
        return res;
    }复制代码

以上所述就是小编给大家介绍的《javascript之数组去重》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Perl语言编程

Perl语言编程

[美] Larry Wall、Tom Christiansen、Jon Orwant / 何伟平 / 中国电力出版社 / 2001-12 / 129.00元

这不仅仅是一本关于Perl的书籍,更是一本独一无二的开发者自己介绍该语言及其文化的书籍。Larry Wall是Perl的开发者,他就这种语言的未来发展方向提出了自己的看法。Tom Christiansen是最早的几个拥护者之一,也是少数几个在错综复杂的中游刃有余的人之一。Jon Orwant是《Perl Journal》的主编,该杂志把Perl社区组合成了一个共同的论坛,以进行Perl新的开发。一起来看看 《Perl语言编程》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

MD5 加密
MD5 加密

MD5 加密工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具