• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >JavaScript > ES5 ES6中Array对象去除重复项的方法总结

ES5 ES6中Array对象去除重复项的方法总结

作者:Microzz 字体:[增加 减小] 来源:互联网 时间:2017-05-11

Microzz通过本文主要向大家介绍了es5 es6,es5 es6 继承,es5和es6的区别,es3 es5 es6,es6转换es5等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

输入例子

[false, true, undefined, null, NaN, 0, 1, {}, {}, 'a', 'a', NaN].uniq()
</div>

输出例子

[false, true, undefined, null, NaN, 0, 1, {}, {}, 'a']
</div>

分析

题目要求给 Array 添加方法,所以我们需要用到 prototype。数组去重本身算法不是很难,但是在 JavaScript 中很多人会忽视 NaN 的存在,因为在 JS 中 NaN !== NaN 。但是在去重中我们又不能保留两个 NaN ,所以需要进行一下判断,这是很多人容易忽视的。

ES5的实现如下:

代码

Array.prototype.uniq = function () {
 var arr = [];
 var flag = true;
 this.forEach(function(item) {
 // 排除 NaN (重要!!!)
 if (item != item) {
 flag && arr.indexOf(item) === -1 ? arr.push(item) : '';
 flag = false;
 } else {
 arr.indexOf(item) === -1 ? arr.push(item) : ''
 }
 });
 return arr;
}
</div>

验证

我们只需要在数组上直接调用 uniq 方法就可以了,如:

[false, true, undefined, null, NaN, 0, 1, {}, {}, 'a', 'a', NaN].uniq()
</div>

结果为:

[false, true, undefined, null, NaN, 0, 1, {}, {}, 'a']
</div>

进阶

ES6的实现

ES6新增了 Set 对象,也就是我们所说的“集合”,它类似于数组,但是成员的值都是唯一的,没有重复的值。所以可以方便去重。

Set本身是一个构造函数,用来生成Set数据结构。(详看👉Set和Map数据结构)

如果用ES6为 Array 对象添加一个去除重复项的方法,则可以如下实现:

Array.prototype.uniq = function() {
 return Array.from(new Set(this));
}
</div>

代码中用 Array.from 把 Set 结构转换成数组,当然,你也可以用其他方法,这里不深究。这里去重关键代码只需要一行,是不是非常简单?😄

如果你要优雅一点,可以使用 ES6 的扩展运算符。如下:

Array.prototype.uniq = function() {
 return [...new Set(this)];
}
</div>

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 详解webpack es6 to es5支持配置
  • ES5 ES6中Array对象去除重复项的方法总结
  • React中ES5与ES6写法的区别总结

相关文章

  • 2017-05-11js中的触发事件对象event.srcElement与event.target详解
  • 2017-05-11jQuery插件HighCharts绘制2D柱状图、折线图的组合双轴图效果示例【附demo源码下载】
  • 2017-05-11jQuery实现的简单拖动层示例
  • 2017-05-11js实现时间轴自动排列效果
  • 2017-05-11JavaScript 批量创建数组的方法
  • 2017-05-11svg动画之动态描边效果
  • 2017-05-11canvas绘制环形进度条
  • 2017-05-11jQuery Validate 相关参数及常用的自定义验证规则
  • 2017-05-11基于vue.js轮播组件vue-awesome-swiper实现轮播图
  • 2017-05-11AngularJS 文件上传控件 ng-file-upload详解

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • JavaScript数组和对象的复制
    • angular十大常见问题
    • js实现颜色阶梯渐变效果(Gradient算法)
    • JavaScript表单验证的两种实现方法
    • 用js制作淘宝放大镜效果
    • 微信小程序 页面传值详解
    • vuejs开发组件分享之H5图片上传、压缩及拍照旋转的问题处理
    • ES6新特性五:Set与Map的数据结构实例分析
    • 高效的jQuery代码编写技巧总结
    • node.js+jQuery实现用户登录注册AJAX交互

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有