返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JS利用map整合双数组的小技巧分享
  • 484
分享到

JS利用map整合双数组的小技巧分享

2024-04-02 19:04:59 484人浏览 安东尼
摘要

目录前言模拟数据合并后数据合并思路代码展示&解析第一步第二步第三步第四步全部代码总结前言 最近因公司业务需求编写ECharts图表展示相关公司阶段型业务相关数据变化,需要服

前言

最近因公司业务需求编写ECharts图表展示相关公司阶段型业务相关数据变化,需要服务端进行数据查询返回给前端进行数据展示。但是由于反回的数据不便于前端 ECharts展示所以需要进行数据整合,奈何本人经验不足只能请教公司大佬,在大佬帮助下完成了数据整合,并学到一个前所未闻的合并方法今天分享给大家。

模拟数据

下图是将要被合并的两数组

合并后数据

合并后数据要求以时间为唯一的key进行合并双数组内的对象,对象内的值有则展示无则初始化本对象没有的key并初始化值为0(如果表达不清晰下方是最后合并的数据)

合并思路

本次合并所用到的了js的mapp技术,既然是以时间作为唯一的key所以要遍历数组一来初始化一个以时间为key的一个map然后遍历数组二进行数据互补再将处理完的map转换成数组就ok了

代码展示&解析

第一步

先声明模拟数据和创建一个空对象用承载map


      //模拟数据 arr1
      let testArrOne = [
        { date: "2021-8-11", testNumOne: 1 },
        { date: "2021-8-12", testNumOne: 2 },
        { date: "2021-8-13", testNumOne: 3 },
      ];
      //模拟数据 arr2
      let testArrTwo = [
        { date: "2021-8-12", testNumTwo: 2 },
        { date: "2021-8-14", testNumTwo: 4 },
        { date: "2021-8-15", testNumTwo: 5 },
      ];
      //合并方法
      let testMap = {}; //首先声明一个空对象作作为 map

第二步

遍历数组一进行map初始化


   //遍历第一个数组
      testArrOne.forEach((item) => {
        testMap[item.date] = {
          date: item.date, //初始化时间
          testNumOne: item.testNumOne || 0, //初始化测试数据一
          testNumTwo: 0,  //初始化测试数据二
        };
      });
  

然后我们就得到了一个以时间作为唯一key的map 我们打印得到下图数据

第三步

遍历数组二进行相关赋值和初始化操作


    //遍历第二个数组
      testArrTwo.forEach((item) => {
       //如果发现数组一包含时间的map对象就复制如若发现新时间进行初始化赋值空对象
        testMap[item.date] = testMap[item.date] || {}; 
       //赋值时间
        testMap[item.date].date = item.date;
        //赋值测试数据一如果没有就初始化
        testMap[item.date].testNumOne = testMap[item.date].testNumOne || 0;
        //辅助测试数据二
        testMap[item.date].testNumTwo = item.testNumTwo;
      });

打印下map得到整合好的对象 如下

第四步

将 map 转成 arr 就大功告成了


 this.listMapUtils.map2List(testMap);

下面是封装好的 map 与 arr 相互转换的代码


      listMapUtils: {
      //arr转map方法
        list2Map: function(list, key) {
          let map = {};
          if (list && Array.isArray(list) && list.length > 0) {
            list.forEach((item) => {
              item[key] ? (map[item[key]] = item) : "";
            });
          }
          return map;
        },
        //map 转 arr 方法
        map2List: function(map) {
          let list = [];
          if (map && typeof map === "object") {
            for (let key in map) {
              list.push(map[key]);
            }
          }
          return list;
        },
      },


全部代码

因为方便展示 map arr 互转的方法我就在data里申明了 同学们还是不要这样写身为前端还是要有模块化思想的


<template>
  <div></div>
</template>

<script>
export default {
  name: "App",
  data() {
    return {
      listMapUtils: {
        list2Map: function(list, key) {
          let map = {};
          if (list && Array.isArray(list) && list.length > 0) {
            list.forEach((item) => {
              item[key] ? (map[item[key]] = item) : "";
            });
          }
          return map;
        },
        map2List: function(map) {
          let list = [];
          if (map && typeof map === "object") {
            for (let key in map) {
              list.push(map[key]);
            }
          }
          return list;
        },
      },
    };
  },
  created() {
    this.mergeArr();
  },
  methods: {
    mergeArr() {
      //模拟数据 arr1
      let testArrOne = [
        { date: "2021-8-11", testNumOne: 1 },
        { date: "2021-8-12", testNumOne: 2 },
        { date: "2021-8-13", testNumOne: 3 },
      ];
      //模拟数据 arr2
      let testArrTwo = [
        { date: "2021-8-12", testNumTwo: 2 },
        { date: "2021-8-14", testNumTwo: 4 },
        { date: "2021-8-15", testNumTwo: 5 },
      ];

      //合并方法

      let testMap = {}; //首先声明一个空对象作作为 map

      //遍历第一给数组
      testArrOne.forEach((item) => {
        testMap[item.date] = {
          date: item.date,
          testNumOne: item.testNumOne || 0,
          testNumTwo: 0,
        };
      });

      testArrTwo.forEach((item) => {
        testMap[item.date] = testMap[item.date] || {}; //初始化对象
        testMap[item.date].date = item.date;
        testMap[item.date].testNumOne = testMap[item.date].testNumOne || 0;
        testMap[item.date].testNumTwo = item.testNumTwo;
      });
      
      //map 转 arr
      this.listMapUtils.map2List(testMap);
      //得到最后结果
      console.log(this.listMapUtils.map2List(testMap));
    },
  },
};
</script>

<style></style>

总结

到此这篇关于JS利用map整合双数组的文章就介绍到这了,更多相关JS整合双数组内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JS利用map整合双数组的小技巧分享

本文链接: https://lsjlt.com/news/132947.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JS利用map整合双数组的小技巧分享
    目录前言模拟数据合并后数据合并思路代码展示&解析第一步第二步第三步第四步全部代码总结前言 最近因公司业务需求编写ECharts图表展示相关公司阶段型业务相关数据变化,需要服...
    99+
    2024-04-02
  • JS数组实用技巧分享
    本篇内容介绍了“JS数组实用技巧分享”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 删除数组的重复项2...
    99+
    2024-04-02
  • 分享PyCharm的字体大小调整技巧
    PyCharm是一款集成开发环境(IDE),广受Python开发者欢迎。在编写代码的过程中,适合自己的字体大小可以提高工作效率。然而,不同的屏幕分辨率和个人偏好导致了字体大小的调整问题。在本文中,我将与大家分享如何在PyChar...
    99+
    2024-02-03
    pycharm 字体 大小调整
  • 利用VS Code写Python的技巧分享
    本篇内容介绍了“利用VS Code写Python的技巧分享”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!本文基于 VS Code 1.36....
    99+
    2023-06-02
  • 常用的29个CSS小技巧分享
    本篇内容主要讲解“常用的29个CSS小技巧分享”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“常用的29个CSS小技巧分享”吧!1.清除图片下方出现几像素的空白间...
    99+
    2024-04-02
  • vue3provide与inject的使用小技巧分享
    目录vue3 provide与inject使用技巧进入正题父组件child组件son组件vue3的一些实用技巧v-for 和 v-if 不要一起使用(Vue2)vue3 provid...
    99+
    2024-04-02
  • 分享常用的3个C++小技巧
    目录1、头文件是引用<iostream.h>还是<iostream>?2、逗号分割表达式3、在main函数之前运行代码1、头文件是引用<iostream...
    99+
    2024-04-02
  • iOS组件依赖避免冲突的小技巧分享
    问题缘由 本文以 YBImageBrowser[1] 组件举例。 YBImageBrowser 依赖了 SDWebImage,在使用 CocoaPods 集成到项目中时,可能会出现...
    99+
    2022-05-27
    ios 组件 依赖
  • 分享python数据统计的一些小技巧
    最近在用python做数据统计,这里总结了一些最近使用时查找和总结的一些小技巧,希望能帮助在做这方面时的一些童鞋。有些技巧是很平常的用法,平时我们没有注意,但是在特定场景,这些小方法还是能带来很大的帮助。 ...
    99+
    2022-06-04
    小技巧 数据统计 python
  • JavaScript中数组常见的操作技巧分享
    这篇文章主要讲解了“JavaScript中数组常见的操作技巧分享”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript中数组常见的操作技巧分享”...
    99+
    2024-04-02
  • Vue中$once的两个实用小技巧分享
    目录前言清除定时器$once/$emit + async/await 实现 Dialog 同步执行总结前言 在 Vue 中有很多 API 都有很实用的地方,只是需要挖掘适用的场景,这...
    99+
    2024-04-02
  • Python实现对相同数据分箱的小技巧分享
    目录前言思路类型一:数字类型二:元组附:利用Python的cut方法可以对数据进行分箱。总结前言 博主最近工作中刚好用到数据分箱操作(对相同数据进行遍历比较,避免了全部遍历比较,大大...
    99+
    2024-04-02
  • 分享一些不常见却很实用的JS技巧
    前言 编程语言通常暗藏着各种技巧,熟练使用这些技巧可以提高开发效率。JavaScript 就是一门技巧性很强的语言,掌握常见的语法技巧不但可以加深对语言特性的理解,还可以简化代码,提...
    99+
    2024-04-02
  • JS数组方法reduce的妙用分享
    目录1. 基本用法2. 使用技巧(1)数组求和(2)扁平数组(3)数组分组(4)使用 reduce() 代替 filter().map()(5)统计数组元素出现次数(6)串行执行异步...
    99+
    2023-02-01
    JS 数组方法reduce JS reduce使用 JS reduce
  • Oracle中调整系统日期的实用技巧分享
    标题:Oracle中调整系统日期的实用技巧分享 在Oracle数据库中,正确的日期和时间信息对于数据处理和分析至关重要。有时候,在调试和测试过程中,我们可能需要调整系统日期来模拟不同的...
    99+
    2024-03-08
    oracle 日期调整 系统日期 sql语句
  • 今天分享几个少见却很有用的 JS 技巧
    1. “返回”按钮 使用 history.back() 可以创建一个浏览器“返回”按钮。 <button onclick="history.back()"> ...
    99+
    2024-04-02
  • Python读取CSV数据的实用技巧分享
    python 中读取 csv 数据的方法分两种:内置 csv 模块,适用于小型 csv 文件,按行迭代数据;pandas 库,提供 read_csv() 函数,可轻松将 csv 数据加载...
    99+
    2024-04-04
    python csv
  • 怎么利用array_merge()函数将php中的数组整合
    这篇文章主要介绍怎么利用array_merge()函数将php中的数组整合,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!PHP开发环境搭建工具有哪些一、phpStudy,是一个新手入门最常用的开发环境。二、WampS...
    99+
    2023-06-14
  • JS创建或填充任意长度数组的小技巧汇总
    目录前言直接填充法 for 循环 push() 法 Array 构造函数法 在 Array 构造函数后面加上 fill() 方法使用 undefined 填充数组 使用 Array....
    99+
    2024-04-02
  • 关于TypeScript开发的6六个实用小技巧分享
    目录1. 开发之前确定实体类型 2. 请求接口时只需要定义自己需要用到的字段 3. 使用枚举类型 4. DOM元素的类型要正常给 5.对象的类型要怎么给 6.结构赋值时类型怎么给 总...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作