目录

  • 1. 数组扁平化
    • 1.1 toString + split
    • 1.2 reduce
    • 1.3 join + split
    • 1.4 递归 + 循环
    • 1.5 扩展运算符
    • 1.6 flat()
  • 2. 对象扁平化

1. 数组扁平化

数组扁平化就是将多维数组转化为一维数组:

[1, [2, 3, [4, 5]]]  ——>  [1, 2, 3, 4, 5]

1.1 toString + split

先将数组转化为字符串,在使用split将字符串转化为数组:

let arr = [1, [2, 3, [4, 5]]]
function flatten(arr) {return arr.toString().split(',').map( item => Number(item))
}
console.log(flatten(arr)) // [1, 2, 3, 4, 5]

用split形成的数组的每个元素仍然是字符串,需要将其转化为数字

注意: 仅适用于数组元素都是数字的情况

1.2 reduce

reduce方法会对根据回调函数对数组的每个元素进行操作:

let arr = [1, [2, 3, [4, 5]]]
const newArr = function(arr){return arr.reduce((pre,cur)=>pre.concat(Array.isArray(cur)?newArr(cur):cur),[])
}
console.log(newArr(arr)); //[0, 1, 2, 3, 4, 5]

更多reduce()方法的使用:《数组reduce()方法的妙用》

1.3 join + split

join()方法和上面的toString方法类似,都能将数组转化为字符串

function flatten(arr) {return arr.join(',').split(',').map( item => parseInt(item) )
}

1.4 递归 + 循环

function flatten(arr) {var res = [];arr.map(item => {if(Array.isArray(item)) {res = res.concat(flatten(item));} else {res.push(item);}});return res;
}

1.5 扩展运算符

...扩展运算符可以取出参数的所有的可以遍历的对象,并拷贝到当前的对象中

let arr = [1, [2, 3, [4, 5]]] function flatten(arr) {while (arr.some(item => Array.isArray(item))) {arr = [].concat(...arr);}return arr;}console.log(flatten(arr)); // [1, 2, 3, 4, 5]

1.6 flat()

flat()是ES6中的一个数组方法,该方法会按照一个可指定的深度depth递归遍历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回。该方法不会改变原数组

语法: let newArray = arr.flat(depth)

注意:

  • depth为指定要提取嵌套数组的结构深度,默认值为 1
  • flat() 方法会移除数组中的空项
 let arr1 = [1, 2, [3, 4]];arr1.flat(); // [1, 2, 3, 4]// 指定要提取嵌套数组的结构深度为1层let arr2 = [1, 2, [3, 4, [5, 6]]];arr2.flat(1); // [1, 2, 3, 4, [5, 6]]// 指定要提取嵌套数组的结构深度为2层let arr3 = [1, 2, [3, 4, [5, 6]]];arr3.flat(2); // [1, 2, 3, 4, 5, 6]// 使用 Infinity 作为深度,展开任意深度的嵌套数组let arr4 = [1, 2, [3, 4, [5, 6]]]arr4.flat(Infinity); // [1, 2, 3, 4, 5, 6]// 移除数组中的空项let arr5 = [1, 2, , 4, 5];arr5.flat(); // [1, 2, 4, 5]

2. 对象扁平化

对象扁平化就是将复杂的多层的对象转化为一维对象:

let obj = { a: { d: 1 }, d:  2, e: [1, 2] }
function flatten(data) {var result = {};function recurse(cur, prop) {// 如果输入进来的是不是对象,就将其放在数组中,返回if (Object(cur) !== cur) {result[prop] = cur;// 如果输入进来的是数组,长度不为0就递归数组,得出结果} else if (Array.isArray(cur)) {for (var i = 0, len = cur.length; i < len; i++)recurse(cur[i], prop + "[" + i + "]");if (len == 0)  result[prop] = [];} else {var isEmpty = true;for (var p in cur) {isEmpty = false;recurse(cur[p], prop ? prop + "." + p : p);}if (isEmpty && prop)result[prop] = {};}}recurse(data, "");return result;
};
console.log(flatten(obj))  // {a.d: 1, d: 2, e[0]: 1, e[1]: 2}

数组扁平化 对象扁平化相关推荐

  1. js的tree数组对象扁平化思否_JS专题之数组展开

    前言 首先什么是数组展开? 假如现在有这样一个需求:将后台的一个多重 List 数据,展开成一个 List 后,并去重后排序: ["a", "b", [&quo ...

  2. 实现 flatten 扁平化对象和数组

    /**  * 对象扁平化  * 说明:请实现 flatten(input) 函数,input 为一个 javascript 对象(Object 或者 Array),返回值为扁平化后的结果.    * ...

  3. JavaScript 对象扁平化

    JavaScript对象扁平化 我们平时肯定遇到过多层嵌套的对象,name如何将它扁平化呢?一起来看看吧! 函数封装如下: function flatten (obj) {const ans = {} ...

  4. JSON数据处理之扁平化对象输出

    有时候返回json的数据中的属性存在在多个对象之中.我们期望它能够整合起来,去掉对象的外衣.这个简单理解为对象扁平化 @Getter @Setter @ToString public class Ac ...

  5. 问你觉得iOS7为什么要扁平化,扁平化和之前的比有什么优势

    问你觉得iOS7为什么要扁平化,扁平化和之前的比有什么优势 苹果首席设计师谈为何会在iOS上选择扁平风格http://ndnews.oeeee.com/html/201306/11/71078.htm ...

  6. 在asp.net2.0中使用串行化对象实现自定义配置

    在一次升级一个entlib1.0到entlib的高版本程序时,碰到entlib的一个通过XmlSerializer方式实现的自定义配置.而在entlib的高版本中这样的配置不再被支持.可是又不希望修改 ...

  7. 池化对象 RecyclableMemoryStream 在 .netcore 中的使用

    Microsoft.IO.RecyclableMemoryStream 是一个被设计为专门用于提高 Stream 操作的高性能类库,意思很明显,专用于取代 MemoryStream 而生,Recycl ...

  8. 实列化对象 自动调用构造方法

    package day18;public class WaDIu {public static void main(String[] args) {//实列化对象 自动调用构造方法Student s ...

  9. 【Android 插件化】插件化原理 ( JVM 内存数据 | 类加载流程 )

    Android 插件化系列文章目录 [Android 插件化]插件化简介 ( 组件化与插件化 ) [Android 插件化]插件化原理 ( JVM 内存数据 | 类加载流程 ) [Android 插件 ...

  10. iOS 组件化,插件化,模块化设计思路分析

    iOS 组件化,插件化设计思路分析 前言 随着用户的需求越来越多,对App的用户体验也变的要求越来越高.为了更好的应对各种需求,开发人员从软件工程的角度,将App架构由原来简单的MVC变成MVVM,V ...

最新文章

  1. pymongo多结果进行多列排序的代码
  2. form表单中的常用控件
  3. SAP CRM 产品主数据和附件(Attachment)的模型关系
  4. 遮掩java_css之图片下方定位遮掩层
  5. (转)如何压缩SQL Server 2005指定数据库文件和日志的大小?
  6. EVE-NG硬盘扩容,存储海量镜像
  7. 分享:20 本优秀的 Python 电子书
  8. ClickHouse S3 外表调研
  9. Halcon深度学习环境搭建(win下)全网最全教程
  10. 工业大数据技术与应用2017材料整理
  11. 计算机win7教案,win7操作系统教案_相关文章专题_写写帮文库
  12. (转载)【笨木头Lua专栏】基础补充18:Lua的模块编写与module函数
  13. RabbitMQ:消费者和生产者。
  14. 人脸检测(二)--人脸识别样本制作及训练测试
  15. Java JDBC数据库简单使用,封装连接,关闭
  16. python中123+5.0的执行结果_123+5.0的执行结果为()_学小易找答案
  17. 小学生算术测试c语言报告,C语言课程设计报告-小学算术运算测试.doc
  18. 自学了半个月python,感觉没用,怎么办?
  19. Windows磁盘碎片整理
  20. 初学者计算机学什么软件好,「推荐」初学者学电脑绘画用什么软件

热门文章

  1. runtime error解决方法
  2. 【2022年终总结】将哈佛大学Reich数据包中的352例SGDP样本进行Admixture分析的结果
  3. 人工智能是否会改写商业规则
  4. mysql下载速度慢怎么办
  5. 最近再看一遍《X战警》系列
  6. 对车辆路试数据集mtcars进一步分析_【案例】图解电磁阀及其故障诊断分析
  7. 2020年叉车司机证考试题库及叉车司机试题解析
  8. Vue表单设计器的终极解决方案
  9. Android 界面一键变灰/黑白
  10. 老子,他有什么了不起