javascript 数组去重常用方法汇总

mark一些我常用的数组去重的方法

1、set方法

const arr = [1,2,3,1,1,2,3,4,2,1,2,3,4,4,2,2,1,2,3,4]

function reset (arr) {
	return Array.from(new Set(arr))
}

let Arr = reset(arr)
console.log(Arr) //  [1, 2, 3, 4]

Set类似于数组,区别在于它所有的成员都是唯一的,不能有重复的值

2、for循环遍历

const arr = [1,2,3,1,1,2,3,4,2,1,2,3,4,4,2,2,1,2,3,4]

for(let i = 0;i<arr.length;i++) {
	for(let j = i+1;j<arr.length;j++) {
		if (arr[i] === arr[j]) {
			arr.splice(j, 1)
			j--
		}
	}
}

两层for循环 比较arr[i]到 arr[i+1~arr.length] 相同即splice(i+1, 1)去重

3、利用IndexOf去重

const arr = [1,2,3,1,1,2,3,4,2,1,2,3,4,4,2,2,1,2,3,4]
let Arr = []
for(let i = 0; i<arr.length;i++){
	if (Arr.indexOf(arr[i]) === -1) {
		Arr.push(arr[i])
	}
}

indexOf()方法如果找不到就会返回-1

4、sort()排序去重

let arr = [1,2,3,1,1,2,3,4,2,1,2,3,4,4,2,2,1,2,3,4]
arr = arr.sort()
let Arr = []
for(let i = 0; i<arr.length; i++) {
	if (arr[i] !== arr[i+1]) {
		Arr.push(arr[i])
	}
}

先使用sort方法排序好数组。然后比较数组的前后两项是否相同

5、利用includes方法

const arr = [1,2,3,1,1,2,3,4,2,1,2,3,4,4,2,2,1,2,3,4]
let Arr = []
for(let i = 0; i<arr.length;i++){
	if (!Arr.includes(arr[i])) {
		Arr.push(arr[i])
	}
}

同indexOf方法。includes方法用户检测数组是否存在传入的值,存在返回true

6、利用filter方法

const arr = [1,2,3,1,1,2,3,4,2,1,2,3,4,4,2,2,1,2,3,4]
let Arr = arr.filter((item, i, self) => self.indexOf(item, 0) === i)

filter是es6的过滤数组的方法,使用filter结合indexOf方法能比较有效的去重

还有其他很多种数组去重方式就不一一列举了,总之灵活善用方法总会有最优去重法;
一些方法参考了这位大佬的总结,更多请看这位大佬的文章 ==>地址

…end

发布了12 篇原创文章 · 获赞 8 · 访问量 368

猜你喜欢

转载自blog.csdn.net/ZhuAiQuan/article/details/105360871