首页前端开发JavaScriptJavaScript中数组去重的5种方法是什么

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

时间2024-01-29 22:55:02发布访客分类JavaScript浏览1095
导读:收集整理的这篇文章主要介绍了JavaScript中数组去重的5种方法是什么,觉得挺不错的,现在分享给大家,也给大家做个参考。数组去重的5种方法:1、用“[...new Set(arr ]”语句去重;2、用“Array.From(new Se...
收集整理的这篇文章主要介绍了JavaScript中数组去重的5种方法是什么,觉得挺不错的,现在分享给大家,也给大家做个参考。

数组去重的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种方法是什么的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: javascript字符串怎么替换字符下一篇:简单对比看看TypeScript中inte...猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员load

若转载请注明出处: JavaScript中数组去重的5种方法是什么
本文地址: https://pptw.com/jishu/591707.html
javascript字符串怎么替换字符 javascript如何获取字符串长度

游客 回复需填写必要信息