Javascript中内建函数reduce的应用详解


Posted in Javascript onOctober 20, 2016

前言

一般而言,可以通过reduce方法实现的逻辑都可以通过forEach方法来变相的实现,虽然不清楚浏览器的js引擎是如何在C++层面实现这两个方法,但是可以肯定的是reduce方法肯定也存在数组的遍历,在具体实现细节上是否针对数组项的操作和存储做了什么优化,则不得而知。

数组的reduce方法的应用

reduce方法有两个参数,第一个参数是一个callback,用于针对数组项的操作;第二个参数则是传入的初始值,这个初始值用于单个数组项的操作。需要注意的是,reduce方法返回值并不是数组,而是形如初始值的经过叠加处理后的操作。

reduce方法最常见的场景就是叠加。

var items = [10, 120, 1000];

// our reducer function
var reducer = function add(sumSoFar, item) { return sumSoFar + item; };

// do the job
var total = items.reduce(reducer, 0);

console.log(total); // 1130

可以看出,reduce函数根据初始值0,不断的进行叠加,完成最简单的总和的实现。

前文中也提到,reduce函数的返回结果类型和传入的初始值相同,上个实例中初始值为number类型,同理,初始值也可为object类型。

var items = [10, 120, 1000];

// our reducer function
var reducer = function add(sumSoFar, item) {
 sumSoFar.sum = sumSoFar.sum + item;
 return sumSoFar;
};

// do the job
var total = items.reduce(reducer, {sum: 0});

console.log(total); // {sum:1130}

多重叠加

使用reduce方法可以完成多维度的数据叠加。如上例中的初始值{sum: 0} ,这仅仅是一个维度的操作,如果涉及到了多个属性的叠加,如{sum: 0,totalInEuros: 0,totalInYen: 0} ,则需要相应的逻辑进行处理。

在下面的方法中,采用分而治之的方法,即将reduce函数第一个参数callback封装为一个数组,由数组中的每一个函数单独进行叠加并完成reduce操作。所有的一切通过一个manager函数来管理流程和传递初始参数。

var manageReducers = function(reducers) {
 return function(state, item) {
 return Object.keys(reducers).reduce(
  function(nextState, key) {
  reducers[key](state, item);
  return state;
  },
  {}
 );
 }
};

上面就是manager函数的实现,它需要reducers对象作为参数,并返回一个callback类型的函数,作为reduce的第一个参数。在该函数内部,则执行多维的叠加工作( Object.keys() )。

通过这种分治的思想,可以完成目标对象多个属性的同时叠加,完整代码如下:

var reducers = { 
 totalInEuros : function(state, item) {
 return state.euros += item.price * 0.897424392;
 },
 totalInYen : function(state, item) {
 return state.yens += item.price * 113.852;
 }
};

var manageReducers = function(reducers) {
 return function(state, item) {
 return Object.keys(reducers).reduce(
  function(nextState, key) {
  reducers[key](state, item);
  return state;
  },
  {}
 );
 }
};

var bigTotalPriceReducer = manageReducers(reducers);

var initialState = {euros:0, yens: 0};

var items = [{price: 10}, {price: 120}, {price: 1000}];

var totals = items.reduce(bigTotalPriceReducer, initialState);

console.log(totals);

总结

以上就是Javascript中内建函数reduce应用的全部内容,希望本文的内容对大家的学习或者工作能有所帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
如何用js控制frame的隐藏或显示的解决办法
Mar 20 Javascript
利用jQuery实现可以编辑的表格
May 26 Javascript
JS实现倒计时和文字滚动的效果实例
Oct 29 Javascript
jQuery学习笔记之jQuery中的$
Jan 19 Javascript
浅析javascript中函数声明和函数表达式的区别
Feb 15 Javascript
Javascript中3个需要注意的运算符
Apr 02 Javascript
jQuery替换节点用法示例(使用replaceWith方法)
Sep 08 Javascript
jQuery实现遍历XML节点和属性的方法示例
Apr 29 jQuery
微信小程序wepy框架学习和使用心得详解
May 24 Javascript
vue + typescript + 极验登录验证的实现方法
Jun 27 Javascript
JS继承定义与使用方法简单示例
Feb 19 Javascript
jQuery实现简单日历效果
Jul 05 jQuery
基于AngularJS前端云组件最佳实践
Oct 20 #Javascript
分享javascript、jquery实用代码段
Oct 20 #Javascript
基于原生js淡入淡出函数封装(兼容IE)
Oct 20 #Javascript
纯JavaScript手写图片轮播代码
Oct 20 #Javascript
Zabbix添加Node.js监控的方法
Oct 20 #Javascript
Javascript实现图片懒加载插件的方法
Oct 20 #Javascript
Vue.js Ajax动态参数与列表显示实现方法
Oct 20 #Javascript
You might like
修改了一个很不错的php验证码(支持中文)
2007/02/14 PHP
php发送短信验证码完成注册功能
2015/11/24 PHP
验证坐标在某坐标区域内php代码
2016/10/08 PHP
php解决DOM乱码的方法示例代码
2016/11/20 PHP
php使用array_chunk函数将一个数组分割成多个数组
2018/12/05 PHP
PHP实现时间日期友好显示实现代码
2019/09/08 PHP
使用PHP+Redis实现延迟任务,实现自动取消订单功能
2019/11/21 PHP
js png图片(有含有透明)在IE6中为什么不透明了
2010/02/07 Javascript
JavaScript 对任意元素,自定义右键菜单的实现方法
2013/05/08 Javascript
JQuery实现表格中相同单元格合并示例代码
2013/06/26 Javascript
5个书写JavaScript代码的坏习惯,看看你中枪了没?
2014/11/06 Javascript
为何JS操作的href都是javascript:void(0);呢
2015/11/12 Javascript
探索angularjs+requirejs全面实现按需加载的套路
2016/02/26 Javascript
深入剖析JavaScript中的函数currying柯里化
2016/04/29 Javascript
jQuery Pagination分页插件使用方法详解
2017/02/28 Javascript
详解Vue-基本标签和自定义控件
2017/03/24 Javascript
详解微信小程序Radio选中样式切换
2017/07/06 Javascript
AngularJS实现的select二级联动下拉菜单功能示例
2017/10/25 Javascript
安装dbus-python的简要教程
2015/05/05 Python
python获取局域网占带宽最大3个ip的方法
2015/07/09 Python
Python实现优先级队列结构的方法详解
2016/06/02 Python
python实现百度语音识别api
2018/04/10 Python
python 爬虫一键爬取 淘宝天猫宝贝页面主图颜色图和详情图的教程
2018/05/22 Python
django使用admin站点上传图片的实例
2019/07/28 Python
Pycharm使用远程linux服务器conda/python环境在本地运行的方法(图解))
2019/12/09 Python
使用pyhon绘图比较两个手机屏幕大小(实例代码)
2020/01/03 Python
python手机号前7位归属地爬虫代码实例
2020/03/31 Python
Python3实现英文字母转换哥特式字体实例代码
2020/09/01 Python
Python实现给PDF添加水印的方法
2021/01/25 Python
国际礼品店:GiftsnIdeas
2018/05/03 全球购物
社会治安综合治理管理责任书
2014/04/16 职场文书
环境保护标语
2014/06/20 职场文书
出纳试用期工作总结2015
2015/05/28 职场文书
肖申克救赎观后感
2015/06/02 职场文书
CocosCreator入门教程之网络通信
2021/04/16 Javascript
Python网络编程之ZeroMQ知识总结
2021/04/25 Python