• 技术文章 >web前端 >js教程

    JavaScript中数组去重的5种方法是什么

    青灯夜游青灯夜游2021-06-29 15:05:28原创2981

    数组去重的5种方法:1、用“[...new Set(arr)]”语句去重;2、用“Array.from(new Set(arr))”语句去重;3、利用indexOf()去重;4、利用includes()去重;5、利用filter()去重。

    本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

    数组去重的方法

    1、[...new Set(arr)]

    const arr = [1, 2, 3, 2, 3];
    [...new Set(arr)]; // [1, 2, 3]

    这里是通过 ES6 的展开语法将 Set 对象转换成数组;

    2、Array.from(new Set(arr))

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

    由于 Set 中的元素是唯一的,无论是原始值或者是对象引用,所以可以通过将数组转换成 Set 对象来实现去重

    Array.from方法可以将 Set 对象转换成数组

    3、利用indexOf去重

    function unique(arr) {
        if (!Array.isArray(arr)) {
            console.log('type error!')
            return
        }
        var array = [];
        for (var i = 0; i < arr.length; i++) {
            if (array .indexOf(arr[i]) === -1) {
                array .push(arr[i])
            }
        }
        return array;
    }
    var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
    console.log(unique(arr))
       // [1, "true", true, 15, false, undefined, null, NaN, NaN, "NaN", 0, "a", {…}, {…}]  //NaN、{}没有去重

    新建一个空的结果数组,for 循环原数组,判断结果数组是否存在当前元素,如果有相同的值则跳过,不相同则push进数组。

    4、利用includes

    function unique(arr) {
        if (!Array.isArray(arr)) {
            console.log('type error!')
            return
        }
        var array =[];
        for(var i = 0; i < arr.length; i++) {
                if( !array.includes( arr[i]) ) {//includes 检测数组是否有某个值
                        array.push(arr[i]);
                  }
        }
        return array
    }
    var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
        console.log(unique(arr))
        //[1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {…}, {…}]     //{}没有去重

    5、利用filter

    function unique(arr) {
      return arr.filter(function(item, index, arr) {
        //当前元素,在原始数组中的第一个索引==当前索引值,否则返回当前元素
        return arr.indexOf(item, 0) === index;
      });
    }
        var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
            console.log(unique(arr))
    //[1, "true", true, 15, false, undefined, null, "NaN", 0, "a", {…}, {…}]

    【相关推荐:javascript学习教程

    以上就是JavaScript中数组去重的5种方法是什么的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:JavaScript 数组去重
    上一篇:简单对比,看看TypeScript中interface和type间的区别 下一篇:javascript字符串怎么替换字符
    大前端线上培训班

    相关文章推荐

    • JavaScript数组去重的方法总结(附代码)• jquery中如何数组去重复数据• 了解ES6中数组去重的两种方式• javascript数组去重复的方法• javascript可不可以跨平台• javascript常用的数据类型有哪些• JavaScript分不分整数浮点数• JavaScript里的push方法有什么用

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网