栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

Web开发之多列排序解决方案
  • 前言
  • 一、前端传参
  • 二、后端实现
    • 2.1、定义一个枚举类
    • 2.2、根据传参进行排序

前言

最近在开发中,遇到一个需求,

即一个页面中,每个指标都可以进行排序,但是同一时间只允许一个字段进行升序降序操作,这边有一个非常合适的解决方案,故记录下来(这个排序是在内存中进行排序的)

一、前端传参

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

二、后端实现 2.1、定义一个枚举类
public enum StudentRankSortEnum {
  CHECKER_NUMS("score", Comparator.comparing(StudentRankVo::getScore));
  private String type;
  private Comparator comparator;

  StudentRankSortEnum(String type,
      Comparator comparator) {
    this.type = type;
    this.comparator = comparator;
  }
  public static Optional> getValue(String type){
    return Arrays.stream(StudentRankSortEnum.values()).filter(item->item.type.equals(type)).map(item->item.comparator).findFirst();
  }
2.2、根据传参进行排序
//从数据库中查询出来的数据集合
List result = student.list();
if (CollectionUtil.isNotEmpty(result)) {
            //排序,分页
            Comparator comparator = null;
            if (StringUtils.isNotBlank(sortedType)){
                Optional> 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 vos = result;
            //其次按照模板名称排序
            Stream 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());
        }
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/868389.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号