二维数组之根据某个值来归类

151 阅读1分钟
     let finalArr = []
     checkListTogether.map((checkItem, index) => {
      if (finalArr.length) {
        const res = finalArr.some(ele => {
          if (ele.classCode === checkItem.classCode) {
            ele.students.push(checkItem);
          }
          return ele.classCode === checkItem.classCode;
        });
        if (!res) {
          finalArr.push({
            classCode: checkItem.classCode,
            schoolId: checkItem.schoolId,
            students: [{ ...checkItem }]
          });
        }
      } else {
        finalArr.push({
          classCode: checkItem.classCode,
          schoolId: checkItem.schoolId,
          students: [{ ...checkItem }]
        });
      }
    });
    -------------------------------------------------------
    <!--checkListTogether: [-->
    <!--    {-->
    <!--      classCode: checkItem.classCode,-->
    <!--      schoolId: checkItem.schoolId,-->
    <!--      name:'alex'-->
    <!--    }-->
    <!--]-->
    
    <!--finalArr: [-->
    <!--    {-->
    <!--      classCode: checkItem.classCode,-->
    <!--      schoolId: checkItem.schoolId,-->
    <!--      students:[
    <!--        {
    <!--          classCode: checkItem.classCode,-->
    <!--          schoolId: checkItem.schoolId,-->
    <!--          name:'alex'-->
    <!--        }
    <!--      ]-->
    <!--    }-->
    <!--]-->

请看以上代码,业务需求是有一个一维数组checkListTogether类似上方的注释。现在要根据每一项的classCode来做数据的归类,最后由finalArr接收,形式就是把classCode提出来,相同classCode的对象在放到students,变成二位数组。

因为要提取checkListTogether中的项,所以遍历checkListTogether。在每一次遍历中又some遍历finalArr,其中干了两件事。第一,如果匹配到了classCode,就Push到二维数组中。第二,返回是否匹配到的bollen,如果false表示当前一维数组的项在finalArr中没有匹配到,就在finalAarr新加一个属于这个classcode的项。

另外,初始finalArr没有项,是不能遍历的,所以判断第一次要push进去一个值。