js 多维度排序

// 先按deviceState分组,然后每个分组中在按workProgress排序
arr.sort((a, b) => {
  if (a.deviceState === b.deviceState) {
    return a.workProgress === null
      ? 1
      : b.workProgress === null
      ? -1
      : Number(a.workProgress) > Number(b.workProgress)
      ? -1
      : 1
  } else {
    return map[a.deviceState] - map[b.deviceState]
  }
})

先按deviceState分组,然后每个分组中再按workProgress排序(null值过滤出来)

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 表 存储在表中的数据是同一种类型的数据或清单。 数据库中的表有为一个名字来标识自己。 表具有一些特性,这些特性定义...
    蛐蛐囍阅读 1,330评论 0 7
  • 一. Java基础部分.................................................
    wy_sure阅读 3,835评论 0 11
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,220评论 0 52
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,282评论 0 2
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    zwb_jianshu阅读 1,208评论 0 0