JavaScript编程---数组嵌套转单数组

实现一个flatten函数,将一个嵌套多层的数组 array(数组) (嵌套可以是任何层数)转换为只有一层的数组,数组中元素仅基本类型的元素或数组,不存在循环引用的情况。 Ex:

var arr = [1,[2,3,[4,5]],-4,['q',[['a123']]]] 转换成 [1,2,3,4,5,-4,'q','a123']

思路一:拿到一个空数组,循环递归,如果本身是数组,继续递归,如果不是,把数据放进空数组,直到结束

function flatten(arr) {
    var _arr = []
    function _flat(arr) {
        arr.forEach(val = >{
            if (Array.isArray(val)) {
                _flat(val)
            } else {
                _arr.push(val)
            }
        })
        // 可以通过上面的箭头函数来实现 es6写法
        //arr.forEach(function(val){
        //  if (Array.isArray(val)) {
        //      _flat(val)
        //  } else {
        //      _arr.push(val)
        //  }
        // }) 
    }
    _flat(arr) return _arr
}

var arr = [1, [2, 3, [4, 5]], -4, ['q', [['a123']]]]

思路二:通过reduce方法,通过拼接,过程还是上面的过程,判断是否是数组,是的话继续,不是的话拿出来拼接返回一个新的数组

function flatten2(arr) {
    return arr.reduce(function(initArr, currentArr) {
        return initArr.concat(Array.isArray(currentArr) ? flatten2(currentArr) : currentArr)
    },[])
}

着急下班,不写太多东西了,注意一下思路和es6语法,逃~

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 数组在程序设计中,为了处理方便, 把具有相同类型的若干变量按有序的形式组织起来。这些按序排列的同类数据元素的集合称...
    朱森阅读 3,997评论 2 13
  • 感谢社区中各位的大力支持,译者再次奉上一点点福利:阿里云产品券,享受所有官网优惠,并抽取幸运大奖:点击这里领取 你...
    HetfieldJoe阅读 773评论 0 2
  • 本文转载自:众成翻译译者:网络埋伏纪事链接:http://www.zcfy.cc/article/2295原文:h...
    极乐君阅读 269评论 0 6
  • 总是渴望 又重复厌倦 坐在办公室里 看着电脑发呆 找不到自己最想要的东西 总是渴望更多的机会 又陷入每天重复的焦虑...
    说完了吗阅读 283评论 0 0
  • 近期总是有种想着手做点什么的想法,以这副身躯存在于这个世界上已经整26年了,时至今日,一直在过的是日复一日...
    芳华灼灼阅读 322评论 0 0