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进去一个值。