写bug小白 2023-08-10 18:05 采纳率: 95.5%
浏览 11
已结题

一个对象中多个数组如何根据某个属性对数组进行排序

一个对象中多个数组如何根据某个属性对数组进行排序

需求:一个list对象中有多个数组,每个数组中有多条数据,每条数据里有一个排序字段typeOrder,如何根据这一个字段让数组按顺序展示在页面上

对象格式示例:

list:{
    12:[
        {
            id:1,
            typeOrder: 5
        },
        {
            id:2,
            typeOrder: 5
        }
    ],
    34:[
        {
            id:3
            typeOrder: 2,
        },
        {
            id:4
            typeOrder: 2,
        },
        {
            id:5
            typeOrder: 2
        }
    ],
    56:[
        {
            id:6
            typeOrder: 1,
        },
        {
            id:7
            typeOrder: 1,
        },
        {
            id:8
            typeOrder: 1
        }
    ],
}

展示在页面上的顺序

56:[
        {
            id:6
            typeOrder: 1,
        },
        {
            id:7
            typeOrder: 1,
        },
        {
            id:8
            typeOrder: 1
        }
    ],
34:[
        {
            id:3
            typeOrder: 2,
        },
        {
            id:4
            typeOrder: 2,
        },
        {
            id:5
            typeOrder: 2
        }
    ],
12:[
        {
            id:1,
            typeOrder: 5
        },
        {
            id:2,
            typeOrder: 5
        }
    ],
    


有没有什么办法可以做到这个效果!

  • 写回答

2条回答 默认 最新

  • 崽崽的谷雨 2023-08-10 18:56
    关注
    
      let list = {
        100: [
        {
          id: 6,
          typeOrder: 3,
        },
        {
          id: 7,
          typeOrder: 3
        },
        {
          id: 8,
          typeOrder: 3
        }
      ],
      12: [
    
        {
          id: 1,
          typeOrder: 5
        },
        {
          id: 2,
          typeOrder: 5
        }
      ],
      34: [
        {
          id: 3,
          typeOrder: 2,
        },
        {
          id: 4,
          typeOrder: 2,
        },
        {
          id: 5,
          typeOrder: 2
        }
      ],
      56: [
        {
          id: 6,
          typeOrder: 1,
        },
        {
          id: 7,
          typeOrder: 1,
        },
        {
          id: 8,
          typeOrder: 1
        }
      ],
     
    };
    // 将list对象转换为Map对象,并按照typeOrder字段进行排序
    const sortedList = new Map(Object.entries(list).sort((a, b) => a[1][0].typeOrder - b[1][0].typeOrder));
    let newList = {};
    // 遍历排序后的Map对象,将每个元素加入新的newList对象
    sortedList.forEach((value, key) => {
      newList[key] = value;
    });
    console.log(newList);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 9月28日
  • 已采纳回答 9月20日
  • 创建了问题 8月10日

悬赏问题

  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)