es6数组去重的方法是什么
时间:2021-09-13
来源:互联网
今天PHP爱好者给大家带来es6数组去重的方法:1、利用Set对象和数组的from方法,语法“Array.from(new Set(arr))”;2、利用Set和扩展运算符,语法“[...new Set(arr)]”;3、利用Map对象和数组的filter方法。希望对大家有所帮助。
本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。
第一种:利用Set对象和数组的Array.from方法
const newArr = Array.from(new Set(arr));
代码示例:
打印运行后的结果
简单来说,第二种方法比第一种还简单。同样来简单解释一下。
Set是ES6新提供的数据结构,类似于数组,但是本身没有重复值。
Array.from方法用于将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括 ES6 新增的数据结构 Set 和 Map)。
所以set结合Array.from同样可以达到数组去重的效果。不过需要注意的是,主流浏览器像Chrome,Firfox,Opera,Safari,包括微软的Edge,都是支持的,但是唯独IE系列不支持。
第二种:利用Set+扩展运算符 …
第三种办法可以说是更简单
const newArr = [...new Set(arr)];
代码示例:
打印后运行的结果
这就是利用ES6新特性达到数组去重的三种办法,这三种办法有个共同的好处就是代码简洁,对于undefined和NaN也同样可以达到去重的效果~~
第三种: 利用Map对象和数组的filter方法
function unique(arr) {
const res = new Map();
return arr.filter((a) => !res.has(a) && res.set(a, 1))
}
代码示例:
打印后的结果
通过打印我们发现,确实实现了我们想要的效果。那么下面简单来解释一下。
Map对象是ES6提供的一个新的数据结构,其中has的办法是返回一个布尔值,表示某个值是否存在当前的Mp对象之中,set的办法是给Map对象设置key/value。
2filter() 方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。
所以说,Map对象结合filter方法可以达到数组去重的效果~
以上就是es6数组去重的方法是什么的详细内容,更多请关注php爱好者其它相关文章!
-
博德之门3橡树之父的拥抱获得步骤 时间:2025-05-13
-
coreldraw在哪下载 时间:2025-05-13
-
币安买币收不到短信验证码?-手机验证异常解决方案 时间:2025-05-13
-
猫之城非天剧情结局大全一览_猫之城非天角色剧情攻略 时间:2025-05-13
-
摩尔庄园2月年度脚印位置介绍 时间:2025-05-13
-
微博怎么解绑支付宝 时间:2025-05-13
今日更新
-
javascript怎么求100内的奇数和
阅读:18
-
javascript中eval的用法是什么
阅读:18
-
新手篇:如何用ccs制作一个简单的布局(附代码)
阅读:18
-
javascript replace怎么用
阅读:18
-
es6继承和es5继承的区别是什么
阅读:18
-
javascript如何将负数转为正数
阅读:18
-
css怎么让字之间的间隔变大
阅读:18
-
javascript中bind的用法是什么
阅读:18
-
深入了解Angularjs中的视图和指令
阅读:18
-
解决TP获取微信用户信息出现10003错误问题
阅读:18