Js中Array 函数使用方法
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Js中Array 函数使用方法相关的知识,希望对你有一定的参考价值。
遇到数组有关操作,脑子第一反应不要再是嵌套 for 循环了,Array 类型提供了一些遍历有关的函数。
- Array.prototype.forEach() : 把数组每个元素丢到一个处理 function 里面,相当于 for 循环。
- Array.prototype.every() : 所有数组元素处理后全部 return true,那么就 return true,有点像 &&。
- Array.prototype.some() : 只要一个数组元素处理后 return true,那么就 return true,有点像 ||。
- Array.prototype.filter() : 将处理时 return true 的数组元素拿出来组成一个新数组。
- Array.prototype.map() : 对每个数组元素进行处理,并组成一个新数组。
- Array.prototype.reduce() : 像一个累加器一样,把数组元素全部加起来(从左向右)。
- Array.prototype.reduceRight() : 同上,顺序从右向左。
- Array.prototype.square = function () { return this.map(function(n) { return n*n; }); }
-
Array.prototype.average = function () { return this.sum() / this.length; }
-
Array.prototype.sum = function () { return this.reduce(function(a, b) { return a + b; }, 0); }
-
Array.prototype.even = function () { return this.filter(function(item) { return 0 == item % 2; }); }
-
Array.prototype.odd = function () { return this.filter(function(item) { return 0 != item % 2; }); }
例如有道题是要求判断某个值是否存在与一个多层数组(locate([‘a’,’b’,[‘c’,’d’,[‘e’]]],’e’); // should return true)。
var locate = function(arr, v) {
return arr.some(function(e) { return Array.isArray(e) ? locate(e, v) : e === v; });
}
再来一个统计字符串每个字母出现次数的函数:
function count (string) {
var count = {};
string.split(‘‘).forEach(function(s) {
count[s] ? count[s]++ : count[s] = 1;
});
return count;
}
以上是关于Js中Array 函数使用方法的主要内容,如果未能解决你的问题,请参考以下文章
Discord.js Bot 赠品命令:.array() 不是函数