方法一:两层for循环嵌套
外层循环从第一项遍历数组的索引,里层循环遍历外层循环开始的后一项开始
如:第一轮循环外层循环从i=0开始那k就从1开始
第二轮循环i从1开始k从2开始
var arr = [1,6,2,5,4,8,5,2,4,6,3,1,7,1,4]
for (var i = 0; i < arr.length; i++) {
//for从第一个循环遍历数组
for (var k = i + 1; k < arr.length; k++) {
//for循环从第二个开始遍历数组
// 判断有没有相同的 相同就要删除掉后一个
if (arr[i] == arr[k]) {
// 删除后面的第k项
arr.splice(k, 1)
k-- //只有要删除的操作 避免数组塌陷忽略的项 进行-- 继续比较
}
}
}
console.log("重后的数组>>>"+arr)
结果:
方法二:先排序 再一层for循环
先使用sort进行排序
var arr = [1,6,2,5,4,8,5,2,4,6,3,1,7,1,4]
arr.sort(function (a, b) {
return a - b
})
console.log('排序后的数组>>>'+arr)
在用一层for循环判断是否重复,重复的删除后一项
var arr = [1,6,2,5,4,8,5,2,4,6,3,1,7,1,4]
arr.sort(function (a, b) {
return a - b
})
console.log('排序后的数组>>>'+arr)
for (var i = 0; i < arr.length - 1; i++) {
// 判断当前的和紧跟着的后面的项比较 相等就该删除
if (arr[i] == arr[i + 1]) {
arr.splice(i + 1, 1)
i--
}
}
console.log("去重后的数组>>>"+arr)
结果:
方法三:利用对象的key值不重复
var arr = [1,6,2,5,4,8,5,2,4,6,3,1,7,1,4]
//创建一个对象
var obj = {}
// 创建一个新数组用于存放后边对象的key值遍历出来的值
var newArr = []
for (var i = 0; i < arr.length; i++) {
// 把数组的每一项 当做对象的key值
obj[arr[i]] = ' '
}
console.log(obj)
// 获取对象所有的key
//遍历key值
for(var key in obj){
//把key值加入新数组,因为对象的key值为string,-0可以把他转换为number
newArr.push(key -0)
}
//打印出最后的结果
console.log("重后的数组>>>"+newArr)
结果:
方法四:利用新数组
var arr = [1,6,2,5,4,8,5,2,4,6,3,1,7,1,4]
//创建一个新数组
var newArr =[]
for (var i = 0; i < arr.length; i++){
// 应用indexOf找不到返回-1的属性判断新数组里是否有该项,若没有就添加到新数组中
if(newArr.indexOf(arr[i]) == -1){
newArr.push(arr[i])
}
}
console.log("去重后的数组>>>"+newArr)
结果:
注意:!!!
运用数组进行去重时,每删除一项必须进行“- -”操作,用以解决数组塌陷问题!