/*//1.常规的方法
var arr = [1,2,31,1,1,,4];
//在数组原型上绑定方法
Array.prototype.unique = function() {
//提出数组中一个值
var res = [this[0]];
//遍历数组
for(var i = 1; i < this.length; i++) {
//做个标记
var repeat = false;
//遍历空数组,并有重复数据时将开关关掉
for( var j = 0; j < res.length; j++) {
if(this[i] == res[j]) {
repeat = true;
break;
}
}
if(!repeat) {
res.push(this[i]);
}
}
return res;
}
alert(arr.unique());*/
var arr = [1,3,1,31,1];
//2.先把原数组排序,这样重复的数值会相邻,再将数组中前后两项进行对比
/*Array.prototype.unique = function() {
this.sort();
var res = [this[0]];
//数组前后两项对比
for(var i = 0;i < this.length; i++){
if(this[i] != res[res.length - 1]) {
res.push(this[i]);
}
}
return res;
}
alert(arr.unique());*/
//3.放入对象的属性中.利用空对象的属性判断代替了第一种方法中的开关
/*Array.prototype.unique = function() {
var res = [];
var obj = {};
for(var i = 0; i< this.length; i++) {
if(!obj[this[i]]) {
res.push(this[i]);
obj[this[i]] = 1;
}
}
return res;
}
alert(arr.unique());*/
//4.
// ES6
/*function unique (arr) {
const seen = new Map()
return arr.filter((a) => !seen.has(a) && seen.set(a, 1))
}
// or
function unique (arr) {
return Array.from(new Set(arr))
}*/
//5. ES6新方法
console.log(Array.from(new Set(arr)));
//6. 使用indexOf方法