您好,欢迎来到爱go旅游网。
搜索
您的当前位置:首页JavaScript中reduce()方法的使用详解

JavaScript中reduce()方法的使用详解

来源:爱go旅游网

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

更多JavaScript中reduce()方法的使用详解相关文章请关注PHP中文网!

Copyright © 2019- igat.cn 版权所有 赣ICP备2024042791号-1

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务