首页 > 语言 > JavaScript > 正文

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

2024-05-06 16:21:49
字体:
来源:转载
供稿:网友

这篇文章主要介绍了JavaScript中reduce()方法的使用详解,是JS入门学习中的基础知识,需要的朋友可以参考下

JavaScript 数组reduce()方法同时应用一个函数针对数组的两个值(从左到右),以减至一个值。

语法

 

 
  1. array.reduce(callback[, initialValue]); 

下面是参数的详细信息:

callback : 函数执行在数组中每个值

initialValue : 对象作为第一个参数回调的第一次调用使用

返回值:

返回数组的减少单一个值

兼容性

这种方法是一个JavaScript扩展到ECMA-262标准; 因此它可能不存在在标准的其他实现。为了使它工作,你需要添加下面的脚本代码的顶部:

 

 
  1. if (!Array.prototype.reduce) 
  2. Array.prototype.reduce = function(fun /*, initial*/
  3. var len = this.length; 
  4. if (typeof fun != "function"
  5. throw new TypeError(); 
  6.  
  7. // no value to return if no initial value and an empty array 
  8. if (len == 0 && arguments.length == 1) 
  9. throw new TypeError(); 
  10.  
  11. var i = 0; 
  12. if (arguments.length >= 2) 
  13. var rv = arguments[1]; 
  14. else 
  15. do 
  16. if (i in this
  17. rv = this[i++]; 
  18. break
  19.  
  20. // if array contains no values, no initial value to return 
  21. if (++i >= len) 
  22. throw new TypeError(); 
  23. while (true); 
  24.  
  25. for (; i < len; i++) 
  26. if (i in this
  27. rv = fun.call(null, rv, this[i], i, this); 
  28.  
  29. return rv; 
  30. }; 

例子:

 

 
  1. <html> 
  2. <head> 
  3. <title>JavaScript Array reduce Method</title> 
  4. </head> 
  5. <body> 
  6. <script type="text/javascript"
  7. if (!Array.prototype.reduce) 
  8. Array.prototype.reduce = function(fun /*, initial*/
  9. var len = this.length; 
  10. if (typeof fun != "function"
  11. throw new TypeError(); 
  12.  
  13. // no value to return if no initial value and an empty array 
  14. if (len == 0 && arguments.length == 1) 
  15. throw new TypeError(); 
  16.  
  17. var i = 0; 
  18. if (arguments.length >= 2) 
  19. var rv = arguments[1]; 
  20. else 
  21. do 
  22. if (i in this
  23. rv = this[i++]; 
  24. break
  25.  
  26. // if array contains no values, no initial value to return 
  27. if (++i >= len) 
  28. throw new TypeError(); 
  29. while (true); 
  30.  
  31. for (; i < len; i++) 
  32. if (i in this
  33. rv = fun.call(null, rv, this[i], i, this); 
  34.  
  35. return rv; 
  36. }; 
  37.  
  38. var total = [0, 1, 2, 3].reduce(function(a, b){ return a + b; }); 
  39. document.write("total is : " + total );  
  40. </script> 
  41. </body> 
  42. </html> 

这将产生以下结果:

 

 
  1. total is : 6 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选