详解JavaScript之Array.reduce源码解读


Posted in Javascript onNovember 01, 2020

前言

reduce(...)方法对数组中的每个元素执行一个由您提供的reducer函数(升序执行),将其结果汇总为单个返回值(累计作用)

此方法接受两个参数:callback(...)(必选)、initialValue(可选)。
callback(...)接受4个参数:Accumulator (acc) (累计器)、Current Value (cur) (当前值)、Current Index (idx) (当前索引)、Source Array (src) (源数组)。

注意点:
1、callback(...)一般需要返回值
2、不会改变原数组

实现思路
1、先获取初始累计的值(分成两种情况:有提供initialValue || 未提供initialValue)
2、遍历数组并执行callback(...)
3、返回累计值

源码实现

Array.prototype.myReduce = function(callback, initialValue) {
 if(this === null) {
  throw new TypeError( 'Array.prototype.reduce called on null or undefined' );
 }
 if (typeof callback !== 'function') {
  throw new TypeError( callback + ' is not a function');
 }
 const O = Object(this);
 const lenValue = O.length;
 const len = lenValue >>> 0;
 if(len === 0 && !initialValue) {
  throw new TypeError('the array contains no elements and initialValue is not provided');
 }
 let k = 0;
 let accumulator;
 // 分成两种情况来获取accumulator
 // 有提供initialValue accumulator=initialValue
 // 没有提供initialValue accumulator=数组的第一个有效元素
 if(initialValue) {
  accumulator = initialValue;
 } else {
  let kPressent = false;
  while(!kPressent && k < len) {
   const pK = String(k);
   kPressent = O.hasOwnProperty(pK);
   if(kPressent) {
    accumulator = O[pK];
   };
   k++;
  }
  if(!kPressent) {
   throw new TypeError('the array contains error elements');
  }
 }
 // 当accumulator=initialValue时 k=0
 // accumulator=数组的第一个有效元素时 k=1
 while(k < len) {
  if(k in O) {
   // callback一般需要返回值
   accumulator = callback(accumulator, O[k], k, O);
  }
  k++;
 }
 return accumulator;
}
let r = [1,2,3].myReduce(function (prevValue, currentValue, currentIndex, array) {
 return prevValue + currentValue;
}, 22);
console.log(r); // 28

参考链接:

reduce-mdn
官方规范

到此这篇关于详解JavaScript之Array.reduce源码解读的文章就介绍到这了,更多相关JavaScript Array.reduce源码内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
转自Jquery官方 jQuery1.1.3发布,速度提升800%,体积保持20K
Aug 19 Javascript
利用WebBrowser彻底解决Web打印问题(包括后台打印)
Jun 22 Javascript
使用javascipt---实现二分查找法
Apr 10 Javascript
javascript校验价格合法性实例(必须输入2位小数)
May 05 Javascript
基于jQuery插件实现环形图标菜单旋转切换特效
May 15 Javascript
Bootstrap入门书籍之(零)Bootstrap简介
Feb 17 Javascript
JavaScript+canvas实现七色板效果实例
Feb 18 Javascript
深入解析JavaScript中函数的Currying柯里化
Mar 19 Javascript
Window.Open打开窗体和if嵌套代码
Apr 15 Javascript
深入理解JavaScript内置函数
Jun 03 Javascript
js继承实现方法详解
Dec 16 Javascript
vue 解决computed修改data数据的问题
Nov 06 Javascript
微信小程序实现星星评分效果
Nov 01 #Javascript
Express 配置HTML页面访问的实现
Nov 01 #Javascript
ant design vue 表格table 默认勾选几项的操作
Oct 31 #Javascript
浅谈Vue使用Cascader级联选择器数据回显中的坑
Oct 31 #Javascript
Ant design vue中的联动选择取消操作
Oct 31 #Javascript
Ant Design Vue table中列超长显示...并加提示语的实例
Oct 31 #Javascript
vue中可编辑树状表格的实现代码
Oct 31 #Javascript
You might like
星际中的相关伤害
2020/03/04 星际争霸
PHP 创建文件(文件夹)以及目录操作代码
2010/03/04 PHP
PHP详解ASCII码对照表与字符转换
2011/12/05 PHP
codeigniter数据库操作函数汇总
2014/06/12 PHP
PHP编写登录验证码功能 附调用方法
2016/05/19 PHP
纯JS实现五子棋游戏兼容各浏览器(附源码)
2013/04/24 Javascript
对于this和$(this)的个人理解
2013/09/08 Javascript
jQuery中:reset选择器用法实例
2015/01/04 Javascript
JavaScript创建闭包的两种方式的优劣与区别分析
2015/06/22 Javascript
JavaScript判断是否是微信浏览器
2016/06/13 Javascript
JS插件plupload.js实现多图上传并显示进度条
2016/11/29 Javascript
详解微信开发中snsapi_base和snsapi_userinfo及静默授权的实现
2017/03/11 Javascript
Vue开发之封装分页组件与使用示例
2019/04/25 Javascript
layui的数据表格+springmvc实现搜索功能的例子
2019/09/28 Javascript
node.js中事件触发器events的使用方法实例分析
2019/11/23 Javascript
javaScript代码飘红报错看不懂?读完这篇文章再试试
2020/08/19 Javascript
[50:12]EG vs Fnatic 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
python线程池的实现实例
2013/11/18 Python
Python实现的tab文件操作类分享
2014/11/20 Python
Python二维码生成库qrcode安装和使用示例
2014/12/16 Python
利用Python的Flask框架来构建一个简单的数字商品支付解决方案
2015/03/31 Python
Python多层嵌套list的递归处理方法(推荐)
2016/06/08 Python
Python温度转换实例分析
2018/01/17 Python
python实现海螺图片的方法示例
2019/05/12 Python
Python 列表去重去除空字符的例子
2019/07/20 Python
python 数据提取及拆分的实现代码
2019/08/26 Python
简单了解python协程的相关知识
2019/08/31 Python
PYQT5 vscode联合操作qtdesigner的方法
2020/03/24 Python
python tkinter的消息框模块(messagebox,simpledialog)
2020/11/07 Python
CSS3 制作绽放的莲花采用效果叠加实现
2013/01/31 HTML / CSS
IWOOT美国:新奇的小玩意
2018/04/27 全球购物
逻辑链路控制协议
2016/10/01 面试题
举例说明类变量和实例变量的区别
2016/06/30 面试题
英文版区域经理求职信
2013/10/23 职场文书
工程安全员岗位职责
2014/03/09 职场文书
2015年干部教育培训工作总结
2015/05/15 职场文书