全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript常见的五种数组去重的方式

大致介绍

JavaScript的数组去重问题在许多面试中都会遇到,现在做个总结

先来建立一个数组

var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN];

第一种

思路:建立一个临时数组,用for循环去依次判断arr中的每个项在临时数组中是否有相同的值,如果没有则将这个值添加到临时数组,如果有相同的值则不添加,最后返回这个临时数组

代码:

Array.prototype.removeDuplicate = function(){
  var n = [];
  for(var i=0;i<this.length;i++){
  if(n.indexOf(this[i]) == -1 ){
  n.push(this[i]);
  }
  }
 return n;
}
var m = arr.removeDuplicate();
console.log(m);//[1, 2, 3, "我", 34, "我的", NaN, NaN]

注意:不会去掉重复的NaN值

第二种   

思路:建立一个临时数组,用for循环利用indexOf()方法去依次判断arr中的每个项在arr中第一次出现的位置,如果这个项在arr中第一次出现的位置就是它的位置,表明在它之前没有相同的值则把它添加到临时数组中,如果这个项在arr中第一次出现的位置不是他的位置则表明在它之前有相同的值,则不把他添加到临时数组中;最后返回临时数组

代码:

Array.prototype.removeDuplicate = function(){
  var n = [];
  for(var i=0;i<this.length-1;i++){
  if(this.indexOf(this[i]) == i){
  n.push(this[i]);
  }
  }
 return n;
 }
 var m = arr.removeDuplicate();
 console.log(m);//[1, 2, 3, "我", 34, "我的"]

注意:会把NaN值删除

第三种

思路:建立一个临时对象,利用for循环检测这个临时对象有没有arr[i]这个属性,如果没有这个属性表明arr[i]在它之前没有和它重复的值。把临时对象的arr[i]属性设置为true,表明有这个属性并把这个项添加到临时数组中;最后返回临时数组

代码:

Array.prototype.removeDuplicate = function(){
  var n = [],m = {};
  for(var i=0;i<this.length;i++){
  if(!m[this[i]]){
  m[this[i]] = true;
  n.push(this[i]);
  }
  }
 return n;
 }
var m = arr.removeDuplicate();
console.log(m);//[1, 2, 3, "我", 34, "我的", NaN]

第四种

思路:先将这个数组排序,然后比较每个项和它后面的项的值是否相等,如果不相等则添加到临时数组中;最后返回临时数组

代码:

Array.prototype.removeDuplicate = function(){
 var n = [];
 this.sort();
 for(var i=0;i<this.length;i++){
 if(this[i] != this[i+1]){
  n.push(this[i]);
  }
 }
 return n;
 }
var m = arr.removeDuplicate();
console.log(m);//[1, 2, 3, 34, NaN, NaN, "我", "我的"]

注意:不会去掉重复的NaN值

第五种

思路:利用ES6的方法set方法去重,并用Array.from转换为数组

set是一种新的数据结构,它可以接收一个数组或者是类数组对象,自动去重其中的重复项目,返回一个对象

代码:

Array.prototype.removeDuplicate = function(){
 return (Array.from(new Set(this)));
 }
 var m = arr.removeDuplicate();
 console.log(m);//[1, 2, 3, "我", 34, "我的", NaN]

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# js  # 数组去重  # JavaScript数组去重和扁平化函数介绍  # JS数组去重详情  # JavaScript数组去重的几种方法详谈  # JavaScript数组去重方案  # JavaScript 数组去重详解  # 七种JS实现数组去重的方式  # 建立一个  # 组中  # 如果没有  # 是一种  # 把他  # 数据结构  # 或者是  # 做个  # 它可以  # 会把  # 设置为  # 并把  # 转换为  # 五种  # 先将  # 先来  # 第二种  # 第一种  # 则将  # 第三种 


相关文章: 如何快速上传自定义模板至建站之星?  ,想在网上投简历,哪几个网站比较好?  专业商城网站制作公司有哪些,pi商城官网是哪个?  如何快速建站并高效导出源代码?  广州建站公司哪家好?十大优质服务商推荐  微信小程序制作网站有哪些,微信小程序需要做网站吗?  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  MySQL查询结果复制到新表的方法(更新、插入)  建站之星后台密码遗忘或太弱?如何重置与强化?  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  魔毅自助建站系统:模板定制与SEO优化一键生成指南  已有域名和空间,如何快速搭建网站?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  如何快速登录WAP自助建站平台?  如何用虚拟主机快速搭建网站?详细步骤解析  大连网站制作公司哪家好一点,大连买房网站哪个好?  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?  如何打造高效商业网站?建站目的决定转化率  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  建站之星IIS配置教程:代码生成技巧与站点搭建指南  潍坊网站制作公司有哪些,潍坊哪家招聘网站好?  打鱼网站制作软件,波克捕鱼官方号怎么注册?  历史网站制作软件,华为如何找回被删除的网站?  C#怎么创建控制台应用 C# Console App项目创建方法  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  如何通过服务器快速搭建网站?完整步骤解析  如何安全更换建站之星模板并保留数据?  高防服务器租用指南:配置选择与快速部署攻略  网站制作价目表怎么做,珍爱网婚介费用多少?  建站之星客服服务时间及联系方式如何?  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  如何在宝塔面板创建新站点?  如何在IIS服务器上快速部署高效网站?  建设网站制作价格,怎样建立自己的公司网站?  定制建站方案优化指南:企业官网开发与建站费用解析  如何在新浪SAE免费搭建个人博客?  建站OpenVZ教程与优化策略:配置指南与性能提升  建站之星如何一键生成手机站?  北京网站制作网页,网站升级改版需要多久?  宝塔Windows建站如何避免显示默认IIS页面?  如何在万网自助建站中设置域名及备案?  建站VPS配置与SEO优化指南:关键词排名提升策略  如何设置并定期更换建站之星安全管理员密码?  如何挑选高效建站主机与优质域名?  建站主机选购指南与交易推荐:核心配置解析  如何优化Golang Web性能_Golang HTTP服务器性能提升方法 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。