javascript如何计算数组中某值的出现次数
更新时间:2023年01月17日 10:41:59 作者:黄元帅
这篇文章主要介绍了javascript如何计算数组中某值的出现次数问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
js计算数组中某值的出现次数
需求
返回一个数组某值出现的次数
- 输入:一个数组
- 输出:需要计数的元素
代码
/* 传入一个数组 返回一个数组某值出现的次数 */ const countOccurences = (arr, value) => arr.reduce((a, v) => v === value ? a + 1 : a + 0, 0); console.log('[1,3,4,6,1,3,5,6,3,1]中 1 出现的次数是:'+countOccurences([1,3,4,6,1,3,5,6,3,1],1));
效果
一点想法
Array的reduce()方法 第一参数是total,第二个参数是初始值
reduce()的参数用法很重要,这在之后的复杂函数里会有所体现。
如何计算数组中某项的个数
<script type="text/javascript"> //统计一个数组中有多少个指定的数据项 var arr1= [12, 5, 8, 130, 44,5,51,5]; //方法一: function count(arr,num){ var total = 0; for (var i = arr.length - 1; i >= 0; i--) { arr[i] === num ? total++ : '' } console.log(total) } count(arr1,5) //方法二: function count1(arr,num){ var countArr = arr.filter(function isBigEnough(value) { return value === num; }); console.log(countArr.length); } count1(arr1,5) //方法三: function count2(arr,num){ var i = 0; arr.forEach(function(ele){ ele === num ? i++ : ''; }) console.log(i) } count2(arr1,5) 方法四: function count3(arr,num){ var i = 0; arr.find(function(ele){ ele === num ? i++ : ''; }) console.log(i) } count3(arr1,5) </script>
说明
1.方法一是通过for循环,在循环体中通过对当前项是否等于指定值的三元运算,对计数器进行累加得到。
2.方法二通过数组的filter方法,返回满足条件的项,组成一个新数组,所以我们判断数组的长度就好了。
3.方法三是利用数组的forEach方法,它会对数组的每一项调用回调函数,类似for循环,之后也是对满足条件的项进行统计。
4.方法四是利用数组的find方法,它也会去数组中寻找符合条件的项,并执行回调函数,所以只需要统计次数就好。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
js中字符串编码函数escape()、encodeURI()、encodeURIComponent()区别详解
JavaScript中有三个可以对字符串编码的函数,分别是: escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent 。接下来通过本文给大家介绍三者之家的区别,感兴趣的朋友一起学习吧2016-04-04
最新评论