JavaScript中reduce()方法的使用详解
程序员文章站
2023-12-03 16:32:43
javascript 数组reduce()方法同时应用一个函数针对数组的两个值(从左到右),以减至一个值。
语法
array.reduce(call...
javascript 数组reduce()方法同时应用一个函数针对数组的两个值(从左到右),以减至一个值。
语法
array.reduce(callback[, initialvalue]);
下面是参数的详细信息:
- callback : 函数执行在数组中每个值
- initialvalue : 对象作为第一个参数回调的第一次调用使用
返回值:
返回数组的减少单一个值
兼容性:
这种方法是一个javascript扩展到ecma-262标准; 因此它可能不存在在标准的其他实现。为了使它工作,你需要添加下面的脚本代码的顶部:
if (!array.prototype.reduce) { array.prototype.reduce = function(fun /*, initial*/) { var len = this.length; if (typeof fun != "function") throw new typeerror(); // no value to return if no initial value and an empty array if (len == 0 && arguments.length == 1) throw new typeerror(); var i = 0; if (arguments.length >= 2) { var rv = arguments[1]; } else { do { if (i in this) { rv = this[i++]; break; } // if array contains no values, no initial value to return if (++i >= len) throw new typeerror(); } while (true); } for (; i < len; i++) { if (i in this) rv = fun.call(null, rv, this[i], i, this); } return rv; }; }
例子:
<html> <head> <title>javascript array reduce method</title> </head> <body> <script type="text/javascript"> if (!array.prototype.reduce) { array.prototype.reduce = function(fun /*, initial*/) { var len = this.length; if (typeof fun != "function") throw new typeerror(); // no value to return if no initial value and an empty array if (len == 0 && arguments.length == 1) throw new typeerror(); var i = 0; if (arguments.length >= 2) { var rv = arguments[1]; } else { do { if (i in this) { rv = this[i++]; break; } // if array contains no values, no initial value to return if (++i >= len) throw new typeerror(); } while (true); } for (; i < len; i++) { if (i in this) rv = fun.call(null, rv, this[i], i, this); } return rv; }; } var total = [0, 1, 2, 3].reduce(function(a, b){ return a + b; }); document.write("total is : " + total ); </script> </body> </html>
这将产生以下结果:
total is : 6