当前项和后面每一项比较
1.indexOf 配合splice
var arr = [1, 2, 3, 4, 2, 3]
for (var i = 0; i < arr.length; i++) {
var item = arr[i]
console.log(item); //123423
var args = arr.slice(i + 1) // 去掉当前要比较的项,方便下一步indexOf进行判断
if (args.indexOf(item) > -1) {
// indexOf 如果未找到和当前项一样的,会返回-1
//现在的条件是>-1 说明后面有重复的
arr.splice(i, 1) //从当前项截取,一个数字。但是循环会i++ ,会造成数组塌陷
i-- //防止数组塌陷
}
}
console.log(arr);
2.indexOf 和替换思维(和第一步基本相同,就是将splice方法换成替换)
var arr = [1, 2, 3, 4, 2, 3]
for (var i = 0; i < arr.length; i++) {
var item = arr[i]
console.log(item); //123423
var args = arr.slice(i + 1)
if (args.indexOf(item) > -1) {
// indexOf 如果未找到和当前项一样的,会返回-1
//现在的条件是>-1 说明后面有重复的
arr[i] = arr[arr.length - 1] //把当前重复的项。 用最后一项,替换当前重复的项
arr.length-- //替换相当于去掉,所以数组长度减一
i-- // 数组塌陷,提前--
}
}
console.log(arr);
3.indexOf +赋值+过滤
var arr = [1, 2, 3, 4, 2, 3]
for (var i = 0; i < arr.length; i++) {
var item = arr[i]
console.log(item); //123423
var args = arr.slice(i + 1)
if (args.indexOf(item) > -1) {
// indexOf 如果未找到和当前项一样的,会返回-1
//现在的条件是>-1 说明后面有重复的
arr[i] = null //把当前重复的全部赋值为null
}
}
// 在输出结果之前,将数组中为null的项,全部过滤
arr = arr.filter(item => item !== null)
console.log(arr);
用新东西存储,再验证有没有存过
创建新数组+indexOf+push
var arr = [1, 2, 3, 4, 2, 3]
var newArr = [] //创建新的空数组
for (var i = 0; i < arr.length; i++) {
var item = arr[i]
var args = arr.slice(i + 1)
if (args.indexOf(item) > -1) {
// indexOf 如果未找到和当前项一样的,会返回-1
//现在的条件是>-1 说明这里有重复的
} else {
// 那else里面存放的就是数组没有重复的项,将没有重复的项,push到新数组里面
newArr.push(item)
}
}
console.log(newArr);