reduce方法应用技巧
程序员文章站
2022-06-24 09:38:21
定义和用法 reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。 注意: reduce() 对于空数组是不会执行回调函数的。 浏览器支持 |方法|Chrome|Edge|Firefox|Safari|Opera| |: :|: :|: :|: :|: ......
定义和用法
reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。
注意: reduce() 对于空数组是不会执行回调函数的。
浏览器支持
方法 | chrome | edge | firefox | safari | opera |
---|---|---|---|---|---|
reduce() | yes | 9.0 | 3.0 | 4 | 10.5 |
语法
array.reduce(function(total, currentvalue, currentindex, arr), initialvalue)
基本用法
基本的数值运算,例如求和:
var numbers = [65, 44, 12, 4]; numbers.reduce(function(total, currentvalue) { return total + currentvalue; });
进阶应用
数组转换为对象
var arr = [{ n: "小明", a: 18, s: "男" }, { n: "小红", a: 17, s: "女" }]; arr.reduce(function(total, currentvalue, currentindex) { total[currentvalue.n] = { age: currentvalue.a, sex: currentvalue.s }; return total; }, {})
链式调用
let pipe = (function() { return function(value, context) { context = context || window; let methods = []; let oproxy = new proxy({}, { get(target, methodname) { if(methodname === 'get') { return methods.reduce((val, fn) => fn(val, context), value); } else { methods.push(context[methodname]); return oproxy; } } }); return oproxy; } })(); let obj = { double: val => val * 2, pow: val => val * val } pipe(4, obj).double.pow.get //64
copyright @ xmwarrior
上一篇: Java 创建并应用PPT幻灯片母版
下一篇: JS数组去重的方法