JavaScript常见的五种数组去重的方式
发布时间 - 2026-01-10 21:50:30 点击率:次大致介绍

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实现数组去重的方式
# 建立一个
# 组中
# 如果没有
# 是一种
# 把他
# 数据结构
# 或者是
# 做个
# 它可以
# 会把
# 设置为
# 并把
# 转换为
# 五种
# 先将
# 先来
# 第二种
# 第一种
# 则将
# 第三种
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
高防服务器租用首荐平台,企业级优惠套餐快速部署
Laravel如何处理异常和错误?(Handler示例)
Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
Bootstrap整体框架之JavaScript插件架构
php 三元运算符实例详细介绍
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
微信小程序 require机制详解及实例代码
企业网站制作这些问题要关注
Claude怎样写约束型提示词_Claude约束提示词写法【教程】
怎样使用JSON进行数据交换_它有什么限制
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
历史网站制作软件,华为如何找回被删除的网站?
Swift中循环语句中的转移语句 break 和 continue
教你用AI将一段旋律扩展成一首完整的曲子
Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】
javascript基本数据类型及类型检测常用方法小结
北京网站制作公司哪家好一点,北京租房网站有哪些?
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
Laravel如何使用.env文件管理环境变量?(最佳实践)
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南
html如何与html链接_实现多个HTML页面互相链接【互相】
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
浅析上传头像示例及其注意事项
简单实现Android验证码
5种Android数据存储方式汇总
JavaScript数据类型有哪些_如何准确判断一个变量的类型
如何撰写建站申请书?关键要点有哪些?
JS经典正则表达式笔试题汇总
Laravel Docker环境搭建教程_Laravel Sail使用指南
Laravel如何构建RESTful API_Laravel标准化API接口开发指南
Laravel如何使用Eloquent ORM进行数据库操作?(CRUD示例)
Laravel如何使用Passport实现OAuth2?(完整配置步骤)
Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解
大连网站制作公司哪家好一点,大连买房网站哪个好?
如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)
如何快速完成中国万网建站详细流程?
如何确保西部建站助手FTP传输的安全性?
Laravel Debugbar怎么安装_Laravel调试工具栏配置指南
如何用搬瓦工VPS快速搭建个人网站?
香港服务器租用每月最低只需15元?
Laravel如何使用Telescope进行调试?(安装和使用教程)
Laravel怎么进行数据库回滚_Laravel Migration数据库版本控制与回滚操作
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】

