1、利用ES6 Set去重(ES6中最常用)
function unique (arr) {
return Array.from(new Set(arr));
}
var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
console.log(unique(arr));
2、利用for嵌套for,然后splice去重(ES5中最常用)
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]){
arr.splice(j,1);
j--;
}
}
}
return arr;
}
var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
console.log(unique(arr));
arrayObject.splice(index,howmany,item1,.....,itemX)
方法:删除从 index 处开始的零个或多个元素,并且用参数列表中声明的一个或多个值来替换那些被删除的元素。前两个参数是必须的。NaN
和{}
没有去重,两个null
直接消失。
3、利用indexOf去重
function unique(arr) {
if (!Array.isArray(arr)) {
console.log('type error!')
return
}
var array = [];
for (var i = 0; i < arr.length; i++) {
if (array .indexOf(arr[i]) === -1) {
array .push(arr[i])
}
}
return array;
}
var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
console.log(unique(arr));
array.indexOf(item,start)
方法:返回数组中某个指定的元素首次出现的位置。第二个可选参数start规定在数组中开始检索的位置。如果没有给出该参数,则将从字符串的首字符开始检索。NaN
和{}
没有去重。
4、利用sort()
function unique(arr) {
if (!Array.isArray(arr)) {
console.log('type error!')
return;
}
arr = arr.sort()
var arrry= [arr[0]];
for (var i = 1; i < arr.length; i++) {
if (arr[i] !== arr[i-1]) {
arrry.push(arr[i]);
}
}
return arrry;
}
var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
console.log(unique(arr));
- 利用
sort()
排序方法,然后根据排序后的结果进行遍历及相邻元素比对。 NaN
和{}
没有去重。
5、利用includes()
function unique(arr) {
if (!Array.isArray(arr)) {
console.log('type error!')
return
}
var array =[];
for(var i = 0; i < arr.length; i++) {
if( !array.includes( arr[i]) ) {
array.push(arr[i]);
}
}
return array;
}
var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
console.log(unique(arr));
includes()
:用来判断一个数组是否包含一个指定的值,如果是返回 true,否则false。{}
没有去重。
6、利用hasOwnProperty()(最完美的方法)
function unique(arr) {
var obj = {};
return arr.filter(function(item){
return obj.hasOwnProperty(typeof item + item) ? false : (obj[typeof item + item] = true);
})
}
var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
console.log(unique(arr));
array.filter()
方法:筛选符合某种条件的元素,将符合条件的元素重新组成一个新的数组。hasOwnProperty()
方法:返回一个布尔值,判断对象自身属性中是否具有指定的属性,但无法检查对象原型链中是否包含某个属性,所以能够检测出来的属性必须是对象成员。- 全部数据类型都可以去重。
7、利用filter+indexOf
function unique(arr) {
return arr.filter(function(item, index) {
return arr.indexOf(item) === index;
});
}
var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
console.log(unique(arr))
8、利用递归(有问题???)
function unique(arr) {
var array= arr;
var len = array.length;
array.sort(function(a,b){
return a - b;
})
function loop(index){
if(index >= 1){
if(array[index] === array[index-1]){
array.splice(index,1);
}
loop(index - 1);
}
}
loop(len-1);
return array;
}
var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
console.log(unique(arr))
9、利用Map数据结构去重(有问题???)
function arrayNonRepeatfy(arr) {
let map = new Map();
let array = new Array();
for (let i = 0; i < arr.length; i++) {
if(map .has(arr[i])) {
map .set(arr[i], true);
} else {
map .set(arr[i], false);
array .push(arr[i]);
}
}
return array ;
}
var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
console.log(unique(arr))
10、利用reduce+includes
function unique(arr){
return arr.reduce((prev,cur) => prev.includes(cur) ? prev : [...prev,cur],[]);
}
var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
console.log(unique(arr));
reduce()
:让数组的前项后项进行某种计算,并返回累计计算的结果。includes()
:用来判断一个数组是否包含一个指定的值,如果是返回 true,否则false。{}
没有去重。