一天一个仿lodash函数实现-flatten

flatten

数组元素铺平一层

function flatten(arr){
  return arr.reduce((pre, cur)=>{
    return pre.concat(cur)
  }, [])
}

flattenDeep

数组元素全部铺平,采用递归的方式,当遇到元素为数组时,继续调用函数来铺平数组,否则直接concat

function flattenDeep(arr) {
  return arr.reduce((pre, cur)=>{
    return cur instanceof Array? pre.concat(flattenDeep(cur)):pre.concat(cur)
  }, [])
}

flattenDepth

按深度铺平元素, 在deep的基础上增加条件判断

function flattenDepth(arr, depth=1) {
  return arr.reduce((pre, cur)=>{
    return cur instanceof Array && depth>1? pre.concat(flattenDepth(cur, depth - 1)):pre.concat(cur)
  }, [])
}
posted @   Dont  阅读(55)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
历史上的今天:
2014-06-14 关于click和submit的笔记
点击右上角即可分享
微信分享提示