1.先将数组用sort进行排序,排序之后进行前后比较;
let arry=['arr1','arr2','rt','tr','rt','11',11]
let nary=arry.sort()
console.log(nary)
for(let i = 0; i < nary.length - 1; i++) {
if(nary[i] === nary[i + 1]) {
console.log("重复内容:" + nary[i]);
}
}
打印结果
2.利用hash值进行判断,如果存在则返回当前值,不存在则将当前值进行存储 下次再循环再使用
(此方法没法判断string类型数字与int类型的数字)
let arry=['arr1','arr2','rt','tr','rt','11']
let nary=arry.sort()
let hash={}
console.log(nary)
for(let i = 0; i < nary.length - 1; i++) {
if(hash[nary[i]]){
console.log("数组重复",nary[i])
}
else{
hash[nary[i]]=true
}
console.log("hash",hash)
}
打印结果
3.ES数组去重之后进行比较长度
let arry=['arr1','arr2','rt','tr','rt','11',11]
let narry= new Set(arry)
console.log(arry,narry,narry.size,arry.length)
打印结果: