js中的数组去重的多种方法
1. indexOf()方法
const arr = [1,2,3,4,5,1,2,3,4,6,1,1,6,6,7,5,8]
const newArr = []
arr.forEach(item => {
if(newArr.indexOf( item ) === -1){
newArr.push( item )
}
})
2. set类型 - ES6最常用,代码最少
const arr = [1,2,3,4,5,1,2,3,4,6,1,1,6,6,7,5,8]
// 将 set 中的数据一个一个解构出来作为数组的数据单元
const newArr = [ ...new Set( arr ) ]
3. 双重for循环 - ES5最常用
const arr = [1,2,3,4,5,1,2,3,4,6,1,1,6,6,7,5,8]
for( let i = 0 ; i <= arr.length-1 ; i++ ){
for( let j = i+1 ; j <= arr.length-1 ; j++ ){
if( arr[i] === arr[j] ){
arr.splice( j , 1)
j--
}
}
}
4. sort排序之后删除 - 消除数组坍塌
const arr = [1,2,3,4,5,1,2,3,4,6,1,1,6,6,7,5,8]
arr.sort(function(a,b){return a-b})
for( let i = 0 ; i <= arr.length-2 ; i++ ){
if( arr[i] === arr[i+1] ){
arr.splice(i+1 , 1)
// 防止数组坍塌
i--
}
}
5. 利用对象没有重复的属性 - 不太建议
const arr = [1,2,3,4,5,1,2,3,4,6,1,1,6,6,7,5,8]
const obj = {}
arr.forEach( item =>{
obj[item] = 1
})
const newArr = []
for( let key in obj ){
newArr.push(key)
}
console.log( newArr )
js中的数组去重的多种方法的更多相关文章
- js数组去重(多种方法)
		
// js数组去重 Array.prototype.fun1 = function(){ var arr = this, result = [], i, len = arr.length; for(i ...
 - JS009. 数组去重的多种方法总结与一步步优化
		
两层for循环 这种函数的优点是兼容性好比较通用,缺点是时空复杂度都很直观的为O(n2),不利于维护和性能. var array = [1,1,'1','1'] function unique(arr ...
 - 面试题常考&必考之--js中的数组去重和字符串去重
		
1.引入:首先得知道数组没有可以直接去重的方法,即直接[].unique()是不支持的, 会报“Uncaught TypeError: [].unique is not a function”错误, ...
 - JS 中检测数组的四种方法
		
今天和大家分享一下 JS 中检测是不是数组的四种方法,虽然篇幅不长,不过方法应该算是比较全面了. 1. instanceof 方法 instanceof 用于检测一个对象是不是某个类的实例,数组也是一 ...
 - js中Array数组的属性和方法
		
这是我自己整理出来的一些关于Array数组的属性和方法,即查即用. 1.Array.length属性:数组的项数组,始终返回0或者更大的值. 2.instanceof操作符:value instanc ...
 - 【python常见面试题】之python 中对list去重的多种方法
		
在python相关职位的面试过程中,会对列表list的去重进行考察.(注意有时会要求保证去重的顺序性) 1.直观方法 li=[1,2,3,4,5,1,2,3] new_li=[] for i in l ...
 - JS中json数组多字段排序方法(解决兼容性问题)(转)
		
前端对一个json数组进行排序,用户需要动态的根据自己的选择来对json数据进行排序. 由于后台表设计问题所以不能用sql进行排序,这里用到了js的sort方法. 如果对单字段排序,那么很简单,一个s ...
 - 转:python中对list去重的多种方法
		
对一个list中的新闻id进行去重,去重之后要保证顺序不变. 直观方法 最简单的思路就是: ids = [1,2,3,3,4,2,3,4,5,6,1] news_ids = [] for id in ...
 - python中对list去重的多种方法
		
今天遇到一个问题,用了 itertools.groupby 这个函数.不过这个东西最终还是没用上. 问题就是对一个list中的新闻id进行去重,去重之后要保证顺序不变. 直观方法 最简单的思路就是: ...
 - js中的数组去重
		
var str=["1","4","5","5","6","1","7 ...
 
随机推荐
- Jetpack架构组件学习(5)——Hilt 注入框架使用
			
原文: Jetpack架构组件学习(5)--Hilt 注入框架使用-Stars-One的杂货小窝 本篇需要有Kotlin基础知识,否则可能阅读本篇会有所困难! 介绍说明 实际上,郭霖那篇文章已经讲得比 ...
 - 仿MFC的消息印射(全局函数的实现)
			
//弄了个仿MFC消息映射,这是全局函数都好弄,照着MFC就弄出来了,//在vs2017上可以通过#include <windows.h> #include "resource. ...
 - zabbix资产清单inventory管理
			
概述 监控的设备越来越多,有时候搞不清楚哪台服务器是什么配置,大多公司有自己的资产清单,要去专门的系统查询显得多少有点麻烦.为此,zabbix专门设置了设备资产管理功能.我们创建或者编辑主机的时候,可 ...
 - 英文短句“xxx for the rest of us”的意思
			
"xxx for the rest of us" 这个短语通常被理解为"为我们所有人"或"为我们剩下的人".为了更好地理解这个短语的意义,我 ...
 - Docker Windows 下的绑定挂载
			
在 Windows 环境下进行绑定挂载时,需要注意路径的写法,需要使用 Windows 风格 (C:\xxx\xxx) 的路径,而不是 Cygwin (/c/xxx/xxx) 风格的路径.这一点在使用 ...
 - Spring框架之IOC介绍
			
Spring之IOC 简介 首先,官网中有这样一句话:Spring Framework implementation of the Inversion of Control (IoC) princip ...
 - C# WebSocket高并发通信阻塞问题
			
项目上遇到使用WebSocket超时问题,具体情况是这样的,OTA升级过程中,解压zip文件会有解压进度事件,将解压进度通过进程通信传给另一进程,通信提示超时异常 小伙伴堂园发现大文件使用Zip解压, ...
 - c++ push_back()和emplace_back()区别
			
c++ push_back()和emplace_back()区别 References C++中push_back和emplace_back的区别 push_back v.s. emplace_bac ...
 - OData – OData vs GraphQL
			
GraphQL 很火, 很厉害, 但是它和 OData 有本质的区别. 所以并不是说任何一样对比另一个绝对的好. GraphQL is not OData twitter 的讨论 有几个点是我能 Ge ...
 - 一款超级给力的弱网测试神器—Qnet(附视频)
			
一.APP弱网测试背景 App在使用的过程中,难免会遇到不同的弱网络环境,像在公车上.在地铁.地下车库等.在这种情况下,手机常常会出现网络抖动.上行或下行超时,导致APP应用中出现丢包延迟,从而影响用 ...