前言 数组是 JS 中使用频率仅次于对象的数据结构,官方提供了众多的 API,谈谈如何扁平化(flatten)数组。...数组的扁平化,是将一个嵌套多层的数组 array (嵌套可以是任何层数)转换为只有一层的数组 flat flat(depth) 方法会递归到指定深度将所有子数组连接,并返回一个新数组, depth指定嵌套数组中的结构深度...flatten(b) : b), []); flatten([1,[2,3],4,[[5,6],7]]) // [1, 2, 3, 4, 5, 6, 7] 复制代码 toString 只适于数组的元素都是数字...([])并将输出解析为数组 const flatten = arr => JSON.parse(`[${ JSON.stringify(arr).replace(/\[|]/g,'')}]`...undercore库或者lodash的中_.flatten函数,具体用法查阅API文档 _.flatten([1, [2], [3, [[4]]]]); => [1, 2, 3, 4]; 复制代码 参考文献 实现扁平化
Array.prototype.flat() flat() 方法会按照一个可指定的深度递归遍历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回。...返回值 一个包含将数组与子数组中所有元素的新数组。...]] var arr3 = [1, 2, [3, 4, [5, 6]]]; arr3.flat(2); // [1, 2, 3, 4, 5, 6] //使用 Infinity,可展开任意深度的嵌套数组...= [1, 2, [3, 4, [5, 6, [7, 8, [9, 10]]]]]; arr4.flat(Infinity); // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] 扁平化与数组空项...flat() 方法会移除数组中的空项: var arr4 = [1, 2, , 4, 5]; arr4.flat(); // [1, 2, 4, 5] 官方文档
概念 数组扁平化是指将一个多维数组变为一维数组。...[1, [2, 3, [4, 5]]] ------> [1, 2, 3, 4, 5] 实现 1. reduce 遍历数组每一项,若值为数组则递归遍历,否则concat。...flatten(item) : item); }, []); } reduce是数组的一种方法,它接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。...return total + item; }, 0); 2. toString & split 调用数组的toString方法,将数组变为字符串然后再用split分割还原为数组 function...arr,若arr[i]为数组则递归遍历,直至arr[i]不为数组然后与之前的结果concat。
一、什么是’扁平化‘ 扁平化的意思对于数组来说,就是将多维数组展开成一维数组或少于当前数组维数的数组。...二、实现扁平化 1、toString 和 split 相结合 思路: toString 可以将多维数组转变成字符串,在通过 split 转换成数组,此时每个元素都为字符串,但需注意的是 此时每个数组元素都为字符串...可以通过迭代的方式进行数组扁平化~ 实现: let arr = [1, [2, [3, 4, 5]]] function reduceArr (arr) { let result = arr.reduce...return result } console.log('结果是:', reduceArr(arr)) // 结果是:[1,2,3,4,5] 3、es6 flat函数 思路: es6的 flat函数实现数组的扁平化...,语法:Array.flat(dep), dep为展开数组的维数(整数),如 dep 是 1, 就是展开1层,如想多维数组都展开成一维数组则 直接 dep 等于 Infinity 。
day024: JS中flat---数组扁平化 对于前端项目开发过程中,偶尔会出现层叠数据结构的数组,我们需要将多层级数组转化为一级数组(即提取嵌套数组元素最终合并为一个数组),使其内容合并且展开。...需求:多维数组=>一维数组 let ary = [1, [2, [3, [4, 5]]], 6];// -> [1, 2, 3, 4, 5, 6] let str = JSON.stringify(ary...cur); }, []); } let ary = [1, 2, [3, 4], [5, [6, 7]]] console.log(flatten(ary)) 6:扩展运算符 //只要有一个元素有数组
// 递归的方法实现扁平化 var arr = [[1, 2, 3], 4, 5, 6, [4, 5], []]; var result = func(arr); function...} else { result.push(item); } } return result; } // es6数组去重...array)); } var arrs = dedupe(result); console.log(result); console.log(arrs); // 数组去重...}); return newArr; } console.log(unique7([1, 1, 2, 3, 5, 3, 1, 5, 6, 7, 4])); // 判断数组
function flatten(arr) { let toString = Object.prototype.toString; let re...
什么是扁平化 一句话解释,数组扁平化是指将一个多维数组(含嵌套)变为一维数组 扁平化之 ES5 toString const arr = [1, 2, 3, [4, 5, [6, 7]]]; const...flatten = arr.toString().split(','); console.log(flatten); 优点:简单,方便,对原数据没有影响 缺点:最好数组元素全是数字或字符,不会跳过空位...[4, 5, [6, 7]]]; const flatten = arr.join(',').split(','); console.log(flatten); 优点和缺点同 toString 扁平化之...,不会修改原数组。...缺点:无 扩展运算符(...) const arr = [1, 2, 3, [4, 5]]; console.log([].concat(...arr)); 优点:简单,方便 缺点:只能扁平化一层 总结
// 数组扁平化,去重,升序 // 方法1,使用es6中的flat()方法扁平化数组,然后new Set去重,最后sort排序 let arr = [1, 3,...arr.sort((a, b) => { return a - b }) console.log(arr); // 方法2,使用toString()方法将数组转化为字符串...,再使用splice()方法,最后map()方法,扁平化数组,然后new Set去重,最后sort排序 let arr1 = [1, 3, 2, [4, 5, 7, [6, 7, 8, [9,
将下面的多维数组打开,输出去重后的结果(扁平化数组) function fn(array, result = []) { for (let i of array) { if (Array.isArray...将需要转化的数组以及结果作为参数传进去。然后循环数组中的每一项,判断是不是一个数组,如果是,则调用fn,否则将这项push到result数组里面,并return出来。
数组扁平化 数组扁平化就是将多层数组拍平成一层,如[1, [2, [3, 4]]]变成[1, 2, 3, 4] 可以使用递归来实现,就直接遍历最外层数组,如果遍历的元素是数组,那就继续递归,直到不是数组为止...也可以使用some()方法来更简单地实现,因为some()方法返回数组是否有元素满足条件的布尔值,因为可以将条件设置为数组中是否有元素是数组。...扁平化) flat 方法实现 - 掘金 大佬讲的非常细,循序渐进介绍了很多种方法。...手写题(搞懂后,提升真的大) - 掘金 GitHub - qianlongo/fe-handwriting: 手写各种js Promise、apply、call、bind、new、deepClone…...面试官连环追问:数组拍平(扁平化) flat 方法实现 - 掘金 (建议精读)原生JS灵魂之问(中),检验自己是否真的熟悉JavaScript? - 掘金
——路遥《早晨从中午开始》 在前端开发中可能会有这样的需求: 将一个数组中的数组拆分出来放到原数组中 那么我们就可以使用flat函数 [1,[2,3,[4,5,6,[7,8,9]]]].flat()...flat中可以传入参数为数字,表示你要拆分数组的层数 如果全部拆分,可以使用flat(Infinity) [1,[2,3,[4,5,6,[7,8,9]]]].flat(Infinity) 如果是较为复杂点的对象
数组拍平也称数组扁平化,就是将数组里面的数组打开,最后合并为一个数组 2.
对于前端项目开发过程中,偶尔会出现层叠数据结构的数组,我们需要将多层级数组转化为一级数组(即提取嵌套数组元素最终合并为一个数组),使其内容合并且展开。那么该如何去实现呢?...需求:多维数组=>一维数组 1....扩展运算符 let list= [1, [2, [3, [4, 5]]],6]; while (list.some(Array.isArray)) { // 将多维数组逐渐展开拼接 list
博客地址: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
三道js手写题的思路和代码实现数组扁平化演示效果将[1, 1, 2, [1, 2]] 变成 1, 1, 2, 1, 2第一种: 直接使用.flatconsole.log([1, [1,2],[1,[2]...]].flat(3));可以将多维数组,降维,传的参数是多少就降多少维一般直接传参数为 Infinity(简单粗暴) 第二种: 递归方法的方法 + 借用数组的API完成(1)function flattten...// some() 方法会依次执行数组的每个元素: // 如果有一个元素满足条件,则表达式返回true , 剩余的元素不会再执行检测。...会将多维数组降维一层 } return arr}第五种: 将多维数组转换成字符串,在进行操作(1)function flatten(arr) { let str = arr.toString...利用Node.js来了解 事件总线var events = require('events');var eventEmitter = new events.EventEmitter();eventEmitter.on
参考文章:面试官连环追问:数组拍平(扁平化) flat 方法实现 编者荐语: 在前端面试中,手写flat是非常基础的面试题,通常出现在笔试或者第一轮面试中,主要考察面试者基本的手写代码能力和JavaScript...()特性 注:数组拍平方法 Array.prototype.flat() 也叫数组扁平化、数组拉平、数组降维。...面试官 N 连问: 第一问:下面数组如何实现扁平化?...因为它们在高版本浏览器并不兼容 方法二:转换为字符串,再把字符串对象用,转换成数组 可以先把多维数组先转换为字符串,再基于,分隔符将字符串对象分割成字符串数组 toString() 扁平化数组 arr...() 数组的话,继续循环 非数组的话,添加到新数组中 返回新数组对象 ES5 实现 flat 扁平化方法 let arr = [ [1, 2, 2], [3, 4, 5, 5],
什么是数组扁平化 将嵌套多层的数组“拉平”,变为一维数组。 为什么要数组扁平化 去除冗余,厚重和繁杂的装饰效果。...如何进行数组扁平化 方法一:递归实现 思路就是通过循环递归的方式,一项一项的去遍历,如果每一项还是一个数组,那么就继续往下遍历,利用递归程序的方法,来实现数组每一项的连接 let arr=[1,[2,...flatten(next):next) },[]) } flatten(arr);// [1,2,3,4,5] 方法三:拓展运算符实现 这个方法的实现,采用了拓展运算符和some的方法,两者共同使用,达到数组扁平化的目的....arr); } return arr; } flatten(arr);// [1,2,3,4,5] 方法四:split和toString 可以通过split和toString两个方法来共同实现数组扁平化...,由于数组会默认带一个toString方法,所以可以把数组直接转换成逗号分隔的字符串,然后再用split方法把字符串重新转换为数组。
三道js手写题的思路和代码实现 数组扁平化 演示效果 将[1, 1, 2, [1, 2]] 变成 1, 1, 2, 1, 2 第一种: 直接使用.flat console.log([1, [1,2],[...1,[2]]].flat(3)); 可以将多维数组,降维,传的参数是多少就降多少维 一般直接传参数为 Infinity(简单粗暴) 第二种: 递归方法的方法 + 借用数组的API完成 (1) function...// some() 方法会依次执行数组的每个元素: // 如果有一个元素满足条件,则表达式返回true , 剩余的元素不会再执行检测。...会将多维数组降维一层 } return arr } 第五种: 将多维数组转换成字符串,在进行操作 (1) function flatten(arr) { let str = arr.toString...利用Node.js来了解 事件总线 var events = require('events'); var eventEmitter = new events.EventEmitter(); eventEmitter.on
flat函数 - 数组扁平化 考虑我们有如下一个数组 const arr = [1, 2, [3, 4], [5, 6, [7, 8]]] 这个数组有很多层,我们现在需要将它变成一层的应该怎么做呢?...initVal) => { const startVal = initVal || []; return arr.reduce((prevRes, item) => { // 如果里层还是数组...initVal) => { const startVal = initVal || []; return arr.reduce((prevRes, item) => { // 如果里层还是数组...} }, startVal) } const arr = [1, 2, [3, 4], [5, 6, [7, 8]]]; const flatArr = flat(arr, 1); // 只扁平化一层...} else { // 如果参数不够,继续接收参数 return (...args2) => { // 注意executeFun接收的参数是平铺的,需要将数组解构
领取专属 10元无门槛券
手把手带您无忧上云