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 相关文章推荐
删除重复数据的算法
Nov 23 Javascript
html中table数据排序的js代码
Aug 09 Javascript
firefox下input type="file"的size是多大
Oct 24 Javascript
javascript 获取元素样式必杀技
May 04 Javascript
JS实现可缩放、拖动、关闭和最小化的浮动窗口完整实例
Mar 04 Javascript
jquery插件之文字间歇自动向上滚动效果代码
Feb 25 Javascript
用js实现放大镜的效果的简单实例
May 23 Javascript
浅谈struts1 & jquery form 文件异步上传
May 25 jQuery
vue-content-loader内容加载器的使用方法
Aug 05 Javascript
微信小程序生成二维码的示例代码
Mar 29 Javascript
Vue Router 实现动态路由和常见问题及解决方法
Mar 06 Javascript
js实现金山打字通小游戏
Jul 24 Javascript
基于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
YII模块实现绑定二级域名的方法
2014/07/09 PHP
在WordPress中使用wp-cron插件来设置定时任务
2015/12/10 PHP
javascript中的delete使用详解
2013/04/11 Javascript
js 程序执行与顺序实现详解
2013/05/13 Javascript
jquery必须知道的一些常用特效方法及使用示例(整理)
2013/06/24 Javascript
页面载入结束自动调用js函数示例
2013/09/23 Javascript
jquery判断RadioButtonList和RadioButton中是否有选中项示例
2013/09/29 Javascript
如何将php数组或者对象传递给javascript
2014/03/20 Javascript
Google Maps API地图应用示例分享
2014/10/23 Javascript
jQuery mobile类库使用时加载导航历史的方法简介
2015/12/04 Javascript
Jquery实现跨域异步上传文件总结
2017/02/03 Javascript
JS操作input标签属性checkbox全选的实现代码
2017/03/02 Javascript
使用node.js实现微信小程序实时聊天功能
2018/08/13 Javascript
使用vuepress搭建静态博客的示例代码
2019/02/14 Javascript
详解Vue.js3.0 组件是如何渲染为DOM的
2020/11/10 Javascript
vue3.0 项目搭建和使用流程
2021/03/04 Vue.js
[44:50]2018DOTA2亚洲邀请赛 4.1 小组赛 A组 TNC vs VG
2018/04/02 DOTA
在Python中使用__slots__方法的详细教程
2015/04/28 Python
PyCharm在win10的64位系统安装实例
2017/11/26 Python
Python实现的桶排序算法示例
2017/11/29 Python
django如何连接已存在数据的数据库
2018/08/14 Python
利用python和百度地图API实现数据地图标注的方法
2019/05/13 Python
Python3.0 实现决策树算法的流程
2019/08/08 Python
jenkins配置python脚本定时任务过程图解
2019/10/29 Python
TensorFlow 读取CSV数据的实例
2020/02/05 Python
Django后端分离 使用element-ui文件上传方式
2020/07/12 Python
CSS实现聊天气泡效果
2020/04/26 HTML / CSS
垃圾回收的优点和原理。并考虑2种回收机制
2016/10/16 面试题
党员培训思想汇报
2014/01/07 职场文书
预备党员思想汇报
2014/01/08 职场文书
社区七一党员活动方案
2014/01/25 职场文书
小学运动会入场式解说词
2014/02/18 职场文书
21岁生日感言
2014/02/27 职场文书
我们的节日端午节活动方案
2014/03/02 职场文书
公司请假条范文
2014/04/11 职场文书
环保小标语
2014/06/13 职场文书