数组扁平化的几种常见方式

数组扁平化 是指将一个多维数组变为一个一维数组

       
	   const arr = [1,[2,[3,[4,5]]],6];
       const res = arr.flat(Infinity)
        console.log(res)

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

        let res1 = flatten(arr)
        console.log(res1)

        // 递归
        let res2 = []
        function fn(arr){
            for (let i=0;i<arr.length;i++){
                if (Array.isArray(arr[i])) {
                    fn(arr[i])
                }else{
                    res2.push(arr[i])
                }
            }
        }
        fn(arr)
        console.log(res2)const arr = [1,[2,[3,[4,5]]],6];

        // 1. 使用 flat()
        const res = arr.flat(Infinity)
        console.log(res)

        // 2.使用 reduce
        function flatten(arr) {
            return arr.reduce((pre,cur)=>{
                return pre.concat(Array.isArray(cur) ? flatten(cur) : cur) 
            },[])
        }

        let res1 = flatten(arr)
        console.log(res1)

        // 3.函数递归
        let res2 = []
        function fn(arr){
            for (let i=0;i<arr.length;i++){
                if (Array.isArray(arr[i])) {
                    fn(arr[i])
                }else{
                    res2.push(arr[i])
                }
            }
        }
        fn(arr)
        console.log(res2)
        // 扩展运算符
        function flaDot(arr) {
            while(arr.some(item=>Array.isArray(item))) {
                arr = [].concat(...arr);
            }
            return arr;
        }
        let res3 = flaDot(arr)
        console.log(res3)
©️2020 CSDN 皮肤主题: 代码科技 设计师:Amelia_0503 返回首页