• 技术文章 >web前端 >前端问答

    es6怎么实现arr(数组)去重

    青灯夜游青灯夜游2022-08-30 17:48:28原创338

    3种实现方法:1、Set数据结构和“Array.from()”去重,语法“Array.from(new Set(arr))”;2、Set数据结构和扩展运算符“...”去重,语法“[...new Set(arr)]”;3、filter()和indexOf()过滤,语法“arr.filter((it,in)=>{return arr.indexOf(it,0)===in;});”。

    大前端成长进阶课程:进入学习

    本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

    ES6数组去重的5种方法

    1、Set数据结构和Array.from()去重

    实现思想:

    语法:

    Array.from(new Set(arr))

    示例:

    let arr=[1,2,3,3,2,"1",0,undefined,undefined];
    let newArr=Array.from(new Set(arr));
    console.log(newArr);

    1.png

    2、Set数据结构和扩展运算符“...”去重

    实现思想:

    语法:

    [...new Set(arr)]

    示例:

    let arr=[1,2,3,3,2,"1",0,1,2];
    let newArr=[...new Set(arr)];
    console.log(newArr);

    2.png

    3、利用数组的 filter+indexOf方法去重

    filter() 方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。

    indexOf方法返回指定元素在数组中的第一个索引(index), 如果没有则返回 -1

    示例:

    var arr=[1, 2, 3, 2, 3];
    var newArr = arr.filter((item,index)=> {
      return arr.indexOf(item,0) === index;
    });
    console.log(newArr);

    3.png

    所以这里的 arr 数组中的每个元素通过 indexOf() 方法返回的索引值分别是 0 1 2 1 2

    arr.forEach(item => console.log(arr.indexOf(item))); // 0 1 2 1 2

    可以通过 indexOf 来实现去重,比如 arr 中的第四个元素 2 通过 indexOf 返回的是索引是 1, 但是它当前的 index 下标是 3,不相等,说明当前的这个 2 元素在之前出现过, 所以应该把它过滤掉。

    【相关推荐:javascript视频教程web前端

    以上就是es6怎么实现arr(数组)去重的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:es6数组 ES6 javascript
    上一篇:es6怎么判断字符串是否为数字 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 实例解析ES6 Promise的原理和使用• 前端es6是模块化开发吗• es6获取顶层对象的方式有哪些• es6和es5可以混合使用吗• es6中static修饰符是啥意思• 一文带你快速详解ES6,认识新增特性!
    1/1

    PHP中文网