JS基于开关思想实现的数组去重功能【案例】
本文实例讲述了JS基于开关思想实现的数组去重功能。分享给大家供大家参考,具体如下:
场景: 比如给你一个数组var Arr = [ 25, 70, 60, 70, 65, 65, 80 ],最终要得到去重后的新数组[25,70,60,65,80].
思路:
1.先定义个空的新数组newArr;
2.遍历旧数组Arr 中所有元素;
3.定义一个isZai变量表示开关,默认为false状态;
4.遍历新数组所有元素与旧数组元素比较(Arr[ i ] == newArr[ j ]);
5.如果该元素存在于新数组中,则改变开关状态为true;
6.根据开关状态实现需求:如果开关为false状态,则将旧数组的元素添加到新数组中;
7.最后打印新数组
js代码如下
<script>
var Arr = [ 25, 70, 60, 70, 65, 65, 80 ];//最终得到[25,70,60,65,80]
//1.先定义个空的新数组newArr;
var newArr=[];
//2.遍历旧数组Arr 中所有元素;
for(var i=0;i<=Arr.length;i++){
//3.定义一个isZai变量表示开关,默认为false状态;
var isZai=false;
for(var j=0;j<=newArr.length;j++){
// 4.遍历新数组所有元素与旧数组元素比较(Arr[ i ] == newArr[ j ]);
if(Arr[ i ] == newArr[ j ]){
//5.如果该元素存在于新数组中,则改变开关状态为true;
isZai=true;//假设被推翻
break;//一旦重复后面没有比较必要
}
}
// 6.根据开关状态实现需求:如果开关为false状态,则将旧数组的元素添加到新数组中;
if(isZai==false){
newArr[newArr.length]=Arr[i];
}
}
console.log ( newArr )//打印新数组[25,70,60,65,80]
</script>
使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码,可得如下运行结果:
PS:这里再为大家提供几款相关工具供大家参考使用:
在线去除重复项工具:
http://tools.jb51.net/code/quchong
在线文本去重复工具:
http://tools.jb51.net/aideddesign/txt_quchong
更多关于JavaScript相关内容还可查看本站专题:《JavaScript数组操作技巧总结》、《JavaScript字符与字符串操作技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript错误与调试技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
以上是 JS基于开关思想实现的数组去重功能【案例】 的全部内容, 来源链接: utcz.com/z/312790.html