array的 filter,some,every等api,亦可用做数组降维(上 接reduce数组降维)
2017-12-28 14:45
821 查看
用filter等方法进行数组降维
昨天说了reduce数组降维,今天突然想到,为什么不能用其他api来降维,应该也是可以,就试了下,果然可以,但还是遇到了些小问题直接上代码了
let array = [2, 3, 5, [8,[ 4, 6, 9]]]; let flatten=function(array){ let arr=[]; array.filter((v)=>{ Array.isArray(v)?arr.push(...flatten(v)):arr.push(v); }) return arr } flatten(array)//[2, 3, 5, 8, 4, 6, 9]
我就试了some,map用上述方法皆可以,every其他一些方法应该都可以
但要注意两点,这些方法,不是在数组api函数内,直接return,而是在外面的函数声明空数组 [] 和 return
若沿用reduce代码结构,方法如下
let array = [2, 3, 5, [8,[ 4, 6, 9]]]; let flatten=function(array){ let arr=[]; return array.filter((v)=>{ Array.isArray(v)? arr.push(...flatten(v)):arr.push(v); return arr }) } flatten(array)//[2, 3, 5, [8,[ 4, 6, 9]]]
可见,并没有成功降维,原因暂时未想明白
可能是因为reduce是累加的原因,
每次都是用上回的结果,而这些api,并不能直接调用上回返回的结果
留个疑问,如果有清楚的同学,请留言,谢谢
相关文章推荐
- ES6数组新增方法forEach、map、filter、find、every、some、reduce的用法
- [置顶] JAVASCRIPT中数组的迭代方法:FOREACH、MAP、FILTER、REDUCE、EVERY、SOME各个说明
- Js数组的map,filter,reduce,every,some方法
- javascript中数组的迭代方法对比:forEach()、map()、reduce()、some()、every()、filter()图解
- js中数组过滤、遍历、迭代every、some、filter、map、forEach、reduce、reduceRight
- 一张图看懂JavaScript中数组的迭代方法:forEach、map、filter、reduce、every、some
- 数组遍历filter,forEach,map,every,some,reduce
- js数组中forEach/some/every/map/filter/reduce的区别
- 一张图看懂JavaScript中数组的迭代方法:forEach、map、filter、reduce、every、some
- JavaScript中数组的迭代方法:forEach、map、filter、reduce、every、some
- javascript中使用迭代操作数组替代for循环(map,filter,some,every,reduce,find )
- 一张图看懂JavaScript中数组的迭代方法:forEach、map、filter、reduce、every、some
- 一张图看懂JavaScript中数组的迭代方法:forEach、map、filter、reduce、every、some
- ES5中Array新增加的API接口 forEach map filter some every indexOf lastIndexOf reduce reduceRight
- javascript利用map,every,filter,some,reduce,sort对数组进行最优化处理
- 5个数组Array方法: indexOf、filter、forEach、map、reduce使用实例(转)
- JS数组filter()、map()、some()、every()、forEach()、lastIndexOf()、indexOf()实例
- js数组的迭代器方法(some、every、forEach、map、filter)
- 数组的迭代方法(every、filter、forEach、map、some)
- 5个数组Array方法: indexOf、filter、forEach、map、reduce使用实例