溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS如何利用map整合雙數(shù)組

發(fā)布時間:2021-08-22 10:33:51 來源:億速云 閱讀:545 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要為大家展示了“JS如何利用map整合雙數(shù)組”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“JS如何利用map整合雙數(shù)組”這篇文章吧。

模擬數(shù)據(jù)

下圖是將要被合并的兩數(shù)組

JS如何利用map整合雙數(shù)組

合并后數(shù)據(jù)

合并后數(shù)據(jù)要求以時間為唯一的key進行合并雙數(shù)組內(nèi)的對象,對象內(nèi)的值有則展示無則初始化本對象沒有的key并初始化值為0(如果表達不清晰下方是最后合并的數(shù)據(jù))

JS如何利用map整合雙數(shù)組

合并思路

本次合并所用到的了js的mapp技術(shù),既然是以時間作為唯一的key所以要遍歷數(shù)組一來初始化一個以時間為key的一個map然后遍歷數(shù)組二進行數(shù)據(jù)互補再將處理完的map轉(zhuǎn)換成數(shù)組就ok了

代碼展示&解析

第一步

先聲明模擬數(shù)據(jù)和創(chuàng)建一個空對象用承載map

  //模擬數(shù)據(jù) arr1
      let testArrOne = [
        { date: "2021-8-11", testNumOne: 1 },
        { date: "2021-8-12", testNumOne: 2 },
        { date: "2021-8-13", testNumOne: 3 },
      ];
      //模擬數(shù)據(jù) arr2
      let testArrTwo = [
        { date: "2021-8-12", testNumTwo: 2 },
        { date: "2021-8-14", testNumTwo: 4 },
        { date: "2021-8-15", testNumTwo: 5 },
      ];
      //合并方法
      let testMap = {}; //首先聲明一個空對象作作為 map

第二步

遍歷數(shù)組一進行map初始化

   //遍歷第一個數(shù)組
      testArrOne.forEach((item) => {
        testMap[item.date] = {
          date: item.date, //初始化時間
          testNumOne: item.testNumOne || 0, //初始化測試數(shù)據(jù)一
          testNumTwo: 0,  //初始化測試數(shù)據(jù)二
        };
      });

然后我們就得到了一個以時間作為唯一key的map 我們打印得到下圖數(shù)據(jù)

JS如何利用map整合雙數(shù)組

第三步

遍歷數(shù)組二進行相關(guān)賦值和初始化操作

//遍歷第二個數(shù)組
      testArrTwo.forEach((item) => {
       //如果發(fā)現(xiàn)數(shù)組一包含時間的map對象就復制如若發(fā)現(xiàn)新時間進行初始化賦值空對象
        testMap[item.date] = testMap[item.date] || {}; 
       //賦值時間
        testMap[item.date].date = item.date;
        //賦值測試數(shù)據(jù)一如果沒有就初始化
        testMap[item.date].testNumOne = testMap[item.date].testNumOne || 0;
        //輔助測試數(shù)據(jù)二
        testMap[item.date].testNumTwo = item.testNumTwo;
      });

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

JS如何利用map整合雙數(shù)組

第四步

將 map 轉(zhuǎn)成 arr 就大功告成了

 this.listMapUtils.map2List(testMap);

下面是封裝好的 map 與 arr 相互轉(zhuǎn)換的代碼

  listMapUtils: {
      //arr轉(zhuǎn)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 轉(zhuǎn) arr 方法
        map2List: function(map) {
          let list = [];
          if (map && typeof map === "object") {
            for (let key in map) {
              list.push(map[key]);
            }
          }
          return list;
        },
      },

全部代碼

因為方便展示 map arr 互轉(zhuǎn)的方法我就在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() {
      //模擬數(shù)據(jù) arr1
      let testArrOne = [
        { date: "2021-8-11", testNumOne: 1 },
        { date: "2021-8-12", testNumOne: 2 },
        { date: "2021-8-13", testNumOne: 3 },
      ];
      //模擬數(shù)據(jù) arr2
      let testArrTwo = [
        { date: "2021-8-12", testNumTwo: 2 },
        { date: "2021-8-14", testNumTwo: 4 },
        { date: "2021-8-15", testNumTwo: 5 },
      ];

      //合并方法

      let testMap = {}; //首先聲明一個空對象作作為 map

      //遍歷第一給數(shù)組
      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 轉(zhuǎn) arr
      this.listMapUtils.map2List(testMap);
      //得到最后結(jié)果
      console.log(this.listMapUtils.map2List(testMap));
    },
  },
};
</script>

<style></style>

以上是“JS如何利用map整合雙數(shù)組”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI