位置: IT常识 - 正文

JS实现数组去重的八种方法(实用)(js 数组去重的四种方法)

编辑:rootadmin
JS实现数组去重的八种方法(实用) 前言

推荐整理分享JS实现数组去重的八种方法(实用)(js 数组去重的四种方法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js中数组去重的方法,js写数组去重,js如何数组去重,js数组去重indexof,js 数组去重的四种方法,js 数组去重,js中数组去重复的方法有哪些,js 数组去重的四种方法,内容如对您有帮助,希望把文章链接给更多的朋友!

js数组去重是比较常见的数组操作方式之一,网上有很多关于数组去重的博客文章,方法各式各样,但有些方法实用性很差,很容易造成不必要的麻烦,所以我们需要去其糟粕取其精华,下面我们就整理一些比较实用的数组去重方法。

Methods 1:利用双重for循环JS实现数组去重的八种方法(实用)(js 数组去重的四种方法)

思路:定义一个新数组,并存放原数组的第一个元素,然后将元素组一一和新数组的元素对比,若不同则存放在新数组中。

function unique(arr) { let newArr = [arr[0]]; for (let i = 1; i < arr.length; i++) { let repeat = false; for (let j = 0; j < newArr.length; j++) { if (arr[i] === newArr[j]) { repeat = true; break; } } if (!repeat) { newArr.push(arr[i]); } } return newArr;}console.log(unique([1, 1, 2, 5, 5, 3, 4, 9, 6, 3, 4]));// 结果是[1, 2, 5, 3, 4, 9, 6]Methods 2:利用对象

思路:利用对象属性存在的特性,如果没有该属性则存入新数组

function unique(arr) { const newArr = [] const obj = {} arr.forEach(item => { if (!obj[item]) { newArr.push(item) obj[item] = true } }) return newArr } console.log(unique([1, 1, 2, 5, 5, 3, 4, 9, 6, 3, 4])) // 结果是[1, 2, 5, 3, 4, 9, 6]Methods 3:利用数组的indexOf方法

思路:新建一个空数组,遍历需要去重的数组,将数组元素存入新数组中,存放前判断数组中是否已经含有当前元素,没有则存入。此方法也无法对NaN去重。

var arr = [1,9,8,8,7,2,5,3,3,3,2,3,1,4,5,444,55,22];function unique(arr) { //定义一个新的临时数组 var newArr=[]; //遍历当前数组 for(var i=0;i<arr.length;i++) { //如果当前数组的第i已经保存进了临时数组,那么跳过, //否则把当前项push到临时数组里面 if(newArr.indexOf(arr[i]) === -1) { //indexOf() 判断数组中有没有字符串值,如果没有则返回 -1 newArr.push(arr[i]); } } return newArr } var arr2 = unique(arr); console.log(arr2); //[ 1, 9, 8, 7, 2, 5, 3, 4, 444, 55, 22]Methods 4:利用数组的includes方法

思路:此方法逻辑与indexOf方法去重异曲同工,只是用includes方法来判断是否包含重复元素。

function unique(arr) { var newArr = [] for (var i = 0; i < arr.length; i++) { if (!newArr.includes(arr[i])) { newArr.push(arr[i]) } } return newArr}console.log(unique([1,5,1,5,3,74,32,7,32,6,9,4,7,4]));// 结果是[1, 5, 3, 74, 32, 7, 6, 9, 4]Methods 5:利用数组的 filter 和 includes方法

同理,filter+indexOf也可

function unique(arr) { var newArr = [] newArr = arr.filter(function (item) { return newArr.includes(item) ? '' : newArr.push(item) }) return newArr}console.log(unique([1,5,1,5,3,74,32,7,32,6,9,4,7,4]));// 结果是[1, 5, 3, 74, 32, 7, 6, 9, 4]Methods 6:利用数组的 forEach 和 includes方法function unique(arr) { let newArr = []; arr.forEach(item => { return newArr.includes(item) ? '' : newArr.push(item); }); return newArr;}console.log(unique([1,1,2,5,6,3,5,5,6,8,9,8]));// 结果是[1, 2, 5, 6, 3, 8, 9]Methods 7:利用数组的 splice 方法。function unique(arr){ for(var i=0;i<arr.length;i++){ for(var j=i+1;j<arr.length;j++){ if(arr[i]==arr[j]){ //如果第一个等于第二个,splice方法删除第二个 arr.splice(j,1); j--; } } } return arr;}var arr = [1,1,2,5,6,3,5,5,6,8,9,8];console.log(unique(arr))//[ 1, 2, 5, 6, 3, 8, 9 ]Methods 8:利用Set()+Array.from()

代码最简洁,原理:

Set对象:是值的集合,你可以按照插入的顺序迭代它的元素。 Set中的元素只会出现一次,即Set中的元素是唯一的。Array.from() 方法:对一个类似数组或可迭代对象创建一个新的,浅拷贝的数组实例。function unique(arr){ return Array.from(new Set(arr))}var arr = [1,1,2,9,6,9,6,3,1,4,5];console.log(unique(arr))//[ 1, 2, 9, 6, 3, 4, 5 ]
本文链接地址:https://www.jiuchutong.com/zhishi/300269.html 转载请保留说明!

上一篇:学习CSS3,模拟春雪漫天飘的动画效果(css3的模块结构和应用)

下一篇:SpringIOC和AOP介绍(spring的aoc和aop)

  • 视同销售增值税申报表怎么填写
  • 劳务公司一般纳税人要交什么税
  • 教育费附加的计征依据包括
  • 企业纳税过程
  • 比较优先股和普通股
  • 编制初始计量有什么要求
  • 结转完工产品生产成本会计科目
  • 可供出售金融资产是指什么
  • 收到销售退回时应当冲减
  • 未支付商标使用费怎么办
  • 建筑企业建安税是多少
  • 发票隔月报送可以么?
  • 财政收回项目资金的整改报告
  • 房地产企业预缴税费
  • 出口退税报关单解密在哪下载
  • 以前年度损益调整属于哪类科目
  • 增值税专用发票和普通发票的区别
  • 公积金账户收入
  • 核定征收是不是不需要发票了
  • 办理金税盘需要多少钱
  • 工资一定要通过应付工资科目吗
  • 财务转账一般多久到账
  • 内部员工购买公司产品
  • 工商企业年报网上申报时间
  • 在win7中,如何将所有窗口进行层叠排列显示
  • win10如何自定义鼠标指针
  • PHP:pg_fetch_result()的用法_PostgreSQL函数
  • 罗汉松的养殖方法剪枝视频
  • php生成随机字符串源,且不会重复出现
  • 会计不忙
  • 收到税务局退回的企业所得税分录
  • 其他综合收益的构成项目如何
  • ls命令的作用
  • 新个税累计预扣怎么算
  • 筹建期间发生的开办费用
  • wordpress站点地址如何设置
  • python Timer定时器如何使用?
  • Building a HTTP Proxy
  • 取得剧本使用费怎么做账
  • 商业保险可以从一家转到另一家吗
  • 关于企业停工停产期间的工资支付有关规定
  • 发票票种核定发票种类怎么选
  • 总公司和子公司可以是一个法人吗
  • 实收资本印花税是一年一交吗
  • 劳务派遣如何做线上业务
  • 房地产企业预缴土地增值税
  • 计算成本时应该考虑什么
  • 工会经费计提比例0.8%
  • 固定资产一旦处于什么状态
  • 职工教育经费开专票可以抵扣吗
  • 银行汇票的适用主体
  • 企业改制后如何脱离原主管部门
  • sql将查询的结果拼接
  • win8.1 multiple edition
  • windows哪个最好用
  • centos如何禁ping
  • winxp设置在哪
  • 晨枫U盘启动工具哪个版本好用
  • win10联想笔记本还原系统
  • linux系统怎么停止ping
  • win7不能自动启动
  • windows8装.NET 3.5时出现0x800F0906错误解决方案
  • win10缺少文件怎么办
  • gnu grub卸载
  • tab栏切换案例
  • forfiles命令详解
  • 原生javascript开发
  • oracle安装使用
  • android怎么真机调试
  • jquery的checked
  • 批量ghost
  • jQuery的 $.ajax防止重复提交的两种方法(推荐)
  • node中异步编程模式使用什么捕获异常
  • javascript的弹窗
  • 安卓端测试
  • 国家税务局网上电子税务局官网重庆
  • 青海国家税务局官网
  • 小规模纳税人在电子税务局怎么报税
  • 云南省残疾人就业服务中心官网
  • 长沙买房后多久可以提取公积金
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设