首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS数组扁平化_扁平化js

前言 数组JS 中使用频率仅次于对象的数据结构,官方提供了众多的 API,谈谈如何扁平化(flatten)数组。...数组扁平化,是将一个嵌套多层的数组 array (嵌套可以是任何层数)转换为只有一层的数组 flat flat(depth) 方法会递归到指定深度将所有子数组连接,并返回一个新数组, depth指定嵌套数组中的结构深度...([])并将输出解析为数组 const flatten = arr => JSON.parse(`[${ JSON.stringify(arr).replace(/\[|]/g,'')}]`...); 复制代码 undercore or lodash 库 使用undercore库或者lodash的中_.flatten函数,具体用法查阅API文档 _.flatten([1, [2], [3, [[...4]]]]); => [1, 2, 3, 4]; 复制代码 参考文献 实现扁平化(flatten)数组的方法还有很多种,可以参考一下文献 javascript-flattening-an-array-of-arrays-of-objects

1.2K20
您找到你想要的搜索结果了吗?
是的
没有找到

面试官:怎样实现JS数组扁平化

一、什么是’扁平化扁平化的意思对于数组来说,就是将多维数组展开成一维数组或少于当前数组维数的数组。...二、实现扁平化 1、toString 和 split 相结合 思路: toString 可以将多维数组转变成字符串,在通过 split 转换成数组,此时每个元素都为字符串,但需注意的是 此时每个数组元素都为字符串...,不包括数组中被删除或从未被赋值的元素,接受四个参数:初始值(或者上一次回调函数返回值),当前元素值,当前索引,调用 reduce 的数组。...可以通过迭代的方式进行数组扁平化~ 实现: let arr = [1, [2, [3, 4, 5]]] function reduceArr (arr) { let result = arr.reduce...思路: es6的 flat函数实现数组扁平化,语法:Array.flat(dep), dep为展开数组的维数(整数),如 dep 是 1, 就是展开1层,如想多维数组都展开成一维数组则 直接 dep

1.2K50

js什么是匿名函数_js函数返回

js匿名函数的代码如下: (function(){ // 这里忽略jQuery 所有实现 })(); 半年前初次接触jQuery 的时候,我也像其他人一样很兴奋地想看看源码是什么样的。...function abc(x,y){ return x+y; } function abc(x,y){ return x+y; }   但是,无论你怎么去定义你的函数JS 解释器都会把它翻译成一个...小括号能把我们的表达式组合分块,并且每一块,也就是每一对小括号,都有一个返回值。这个返回值实际上也就是小括号中表达式的返回值。...也就是函数对象所代表的函数体。   总之,将其(被小括号包含的匿名函数)理解为括号表达式返回函数对象,然后就可以对这个函数对象作正常的参数列表调用了。...所以如果问你那个开篇中的jQuery 代码片段是应用了JS 里的什么特性?那么它只是匿名函数与匿名函数的调用而已。但是,它 隐含了闭包的特性,并且随时可以实现闭包应用。

7.1K20

JS手撕(二) 数组扁平化、浅拷贝、深拷贝

数组扁平化 数组扁平化就是将多层数组拍平成一层,如[1, [2, [3, 4]]]变成[1, 2, 3, 4] 可以使用递归来实现,就直接遍历最外层数组,如果遍历的元素是数组,那就继续递归,直到不是数组为止...也可以使用some()方法来更简单地实现,因为some()方法返回数组是否有元素满足条件的布尔值,因为可以将条件设置为数组中是否有元素是数组。...扁平化) flat 方法实现 - 掘金 大佬讲的非常细,循序渐进介绍了很多种方法。...深拷贝主要是通过递归来实现,如果属性是对象,则递归调用深拷贝函数。...面试官连环追问:数组拍平(扁平化) flat 方法实现 - 掘金 (建议精读)原生JS灵魂之问(中),检验自己是否真的熟悉JavaScript? - 掘金

1.3K10

嵌套数组的合并,扁平化数组

博客地址:https://ainyi.com/19 问题引入 请写一个 flat 方法,实现扁平化嵌套数组 对于 [ [], [], [], ...]...数组里嵌套数组,有个需求:将里面的数组元素都放到外层数组,变成 , , , ......+ 子数组有 13 个元素的数组 let arr = []; for (let i = 0; i < 10000; i++) { arr.push([Math.random()*100, Math.random...双重循环push,(数组元素较长时推荐,速度最快) // 数组里面每个元素都必须是数组才行 // 诸如这样 [[],[],[],[]] 才行,如果这样 [1,[],2,[]] 不行,因为 for of...(速度最慢) // 数组里面每个元素都必须是数组才行 // 诸如这样 [[],[],[],[]] 才行,如果这样 [1,[],2,[]] 不行,因为 ...后接不能是数字 // 用时:34 s newArr

2.1K30
领券