大致介绍

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小时内与您取得联系。