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新建多桌面切换操作【技巧】