Web开发之多列排序解决方案

前言

最近在开发中,遇到一个需求,
在这里插入图片描述
即一个页面中,每个指标都可以进行排序,但是同一时间只允许一个字段进行升序降序操作,这边有一个非常合适的解决方案,故记录下来(这个排序是在内存中进行排序的)

一、前端传参

一个参数是sortedType,即是哪一个字段进行排序,例如传入scorescore后台则是按照score排序,这个对应关系可以放在一个枚举类中,后面有介绍;
另一个参数是sorted,可以规定一下,比如0代表升序,1代表降序

二、后端实现

2.1、定义一个枚举类

public enum StudentRankSortEnum {
  CHECKER_NUMS("score", Comparator.comparing(StudentRankVo::getScore));
  private String type;
  private Comparator<StudentRankVo> comparator;

  StudentRankSortEnum(String type,
      Comparator<StudentRankVo> comparator) {
    this.type = type;
    this.comparator = comparator;
  }
  public static Optional<Comparator<StudentRankVo>> getValue(String type){
    return Arrays.stream(StudentRankSortEnum.values()).filter(item->item.type.equals(type)).map(item->item.comparator).findFirst();
  }

2.2、根据传参进行排序

//从数据库中查询出来的数据集合
List<Student> result = student.list();
if (CollectionUtil.isNotEmpty(result)) {
            //排序,分页
            Comparator<StudentRankVo> comparator = null;
            if (StringUtils.isNotBlank(sortedType)){
                Optional<Comparator<StudentRankVo>> optionalComparator = StudentRankSortEnum.getValue(sortedType);
                //sorted == 1则为降序,否则为默认顺序
                comparator = sorted == 1 ? Optional.ofNullable(optionalComparator.get()).map(i->i.reversed()).orElseGet(null):optionalComparator.get();
            }else {
                //默认按检查人数降序排列
                comparator = StudentRankSortEnum.getValue("score").get().reversed();
            }
            List<StudentRankVo> vos = result;
            //其次按照模板名称排序
            Stream<StudentRankVo> studentRankVoVoStream = Optional.ofNullable(comparator).map(c->c.thenComparing(StudentRankVo::getName)).map(c -> vos.stream().sorted(c)).orElseGet(vos::stream);
            result = studentRankVoVoStream.skip((pageInfo.getPageNumber()-1)*pageInfo.getPageSize()).limit(pageInfo.getPageSize()).collect(Collectors.toList());
        }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值