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

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

  • 前言
  • 一、前端传参
  • 二、后端实现
    • 2.1、定义一个枚举类
    • 2.2、根据传参进行排序

前言

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

一、前端传参

一个参数是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());
        }

你可能感兴趣的:(一些解决方案,java)