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


相关推荐: 如何做网站制作流程,*游戏网站怎么搭建?  如何在建站主机中优化服务器配置?  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  如何快速搭建FTP站点实现文件共享?  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  Python企业级消息系统教程_KafkaRabbitMQ高并发应用  Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比  如何在自有机房高效搭建专业网站?  LinuxShell函数封装方法_脚本复用设计思路【教程】  Laravel怎么在Blade中安全地输出原始HTML内容  ChatGPT 4.0官网入口地址 ChatGPT在线体验官网  Laravel如何使用Vite进行前端资源打包?(配置示例)  如何选择PHP开源工具快速搭建网站?  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  网站建设保证美观性,需要考虑的几点问题!  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案  什么是javascript作用域_全局和局部作用域有什么区别?  Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制  如何用IIS7快速搭建并优化网站站点?  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  公司网站制作需要多少钱,找人做公司网站需要多少钱?  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  高防服务器租用首荐平台,企业级优惠套餐快速部署  装修招标网站设计制作流程,装修招标流程?  HTML 中如何正确使用模板变量为元素的 name 属性赋值  在线制作视频的网站有哪些,电脑如何制作视频短片?  魔毅自助建站系统:模板定制与SEO优化一键生成指南  php增删改查怎么学_零基础入门php数据库操作必知基础【教程】  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  Laravel怎么清理缓存_Laravel optimize clear命令详解  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  SQL查询语句优化的实用方法总结  如何正确下载安装西数主机建站助手?  Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID  IOS倒计时设置UIButton标题title的抖动问题  如何快速打造个性化非模板自助建站?  如何在宝塔面板创建新站点?  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  如何自定义建站之星模板颜色并下载新样式?  网站图片在线制作软件,怎么在图片上做链接?  微信小程序 HTTPS报错整理常见问题及解决方案  如何生成腾讯云建站专用兑换码?  英语简历制作免费网站推荐,如何将简历翻译成英文?  ,南京靠谱的征婚网站?  利用JavaScript实现拖拽改变元素大小  Java垃圾回收器的方法和原理总结  如何快速搭建个人网站并优化SEO?  什么是JavaScript解构赋值_解构赋值有哪些实用技巧