目录

来来来 手写一个数组扁平化

一分钟教会你数组扁平化

哈喽哈喽,大家好,我是你们的金樽清酒,最近在刷b站的时候看到一个标题实现数组扁平化,这让我瞬间来了兴趣,看我自己能不能手搓一个数组扁平化函数出来。嘿嘿嘿,也算是让我写出来了,也不知道代码优不优雅,让掘友来评价一下吧。

什么是数组扁平化

我们一般见到的数组都是一维的,只有一层数组。但是遇到多维数组怎么办呢?也就是数组里面嵌套数组的情况。比如:arr[[1,2,3],[234],3,4,5,[2,3,6,7]]将这个数组要变成 arr:[1,2,3,2,3,4,3,4,5,2,3,6,7],该如何去实现呢?

思路

1.创建一个新的数组 2.遍历数组 3.判断数组里面是否还是数组,不是数组就存入新创建的数组 4.是数组递归调用,这样就可以遍历出数组里面的数组 5.rerun 新数组

整体思路还是比较简单的。

代码

js 复制代码
let arr = [[1, 2, 3], [2, 3, [1, 2, 3], 5], [2, 6, 8, 3], [3, 5, 8, 2, 4]]

function setFlattening(arr) {
    let newArr = []
    function Flattening(arr) {
        let len = arr.length
        for (let i = 0; i < len; i++) {
            if (arr[i] instanceof Array) {
                Flattening(arr[i])
            }
            else {
                newArr.push(arr[i])
            }//递归调用,让里面的数组再存入数组
        }
        return newArr
    }
    return Flattening(arr)
}
console.log(setFlattening(arr));

这里我用外层函数装了一下,是将newarr私有化,放在函数里层又会不断将数组重置。在外层函数里面调用扁平化的函数。达到数组扁平化的效果。

好啦,这样一个简单的数组扁平化就实现啦。开心,这是自己写出来的。

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
木木黄木木1 小时前
html5炫酷3D文字效果项目开发实践
前端·3d·html5
Li_Ning211 小时前
【接口重复请求】axios通过AbortController解决页面切换过快,接口重复请求问题
前端
胡八一2 小时前
Window调试 ios 的 Safari 浏览器
前端·ios·safari
Dontla2 小时前
前端页面鼠标移动监控(鼠标运动、鼠标监控)鼠标节流处理、throttle、限制触发频率(setTimeout、clearInterval)
前端·javascript
再学一点就睡2 小时前
深拷贝与浅拷贝:代码世界里的永恒与瞬间
前端·javascript
CrimsonHu3 小时前
B站首页的 Banner 这么好看,我用原生 JS + 三大框架统统给你复刻一遍!
前端·javascript·css
Enti7c3 小时前
前端表单输入框验证
前端·javascript·jquery
拉不动的猪3 小时前
几种比较实用的指令举例
前端·javascript·面试
麻芝汤圆3 小时前
MapReduce 的广泛应用:从数据处理到智能决策
java·开发语言·前端·hadoop·后端·servlet·mapreduce
与妖为邻3 小时前
自动获取屏幕尺寸信息的html文件
前端·javascript·html