- 借助新数组去重(最简单的方法)
var arr = [1,1,2,1,3,2,1,1,5,6,8,9,6];
var arr1 = [];
arr.forEach(item=>{
if(arr1.indexOf(item)<0){
arr1.push(item)
}
})
console.log(arr1)
- Es6新方法Set
var arr = [1,1,2,1,3,2,1,1,5,6,8,9,6];
function deduplication (arr) {
//ES6新增方法,似于数组,但它的一大特性就是所有元素都是唯一的,没有重复。
return Array.from(new Set(arr))
}
- 利用两层for循环,使用splice去重
function deduplication(arr){
for(var i=0; i<arr.length; i++){
for(var j=i+1; j<arr.length; j++){
if(arr[i]==arr[j]){
arr.splice(j,1);
j--;
}
}
}
return arr;
}
- 先用sort()方法排序,在判断相邻元素是否相等
function deduplication(arr) {
arr = arr.sort(function(b,a) {
return b - a;
});
var arr1=[arr[0]];
for(var i=1;i<arr.length;i++){
if(arr[i]!=arr[i-1]){
arr1.push(arr[i]);
}
}
return arr1;
}
以上就是数组去重的常用方法,欢迎补充。
也可以了解一下这个大佬的文章,有很多干货