java拖拽排序实现_dw拖动ap元素取消是灰的

java拖拽排序实现_dw拖动ap元素取消是灰的@ApiOperation(value=”板块拖动排序”)@ApiImplicitParams({@ApiImplicitParam(name=”plateId1″,value=”拖拽体”),@ApiImplicitParam(name=”plateId2″,value=”参照体”),@ApiImplicitParam(name=”type”,value=”实现类型1交换位置2挤压位置.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

@ApiOperation(value = "板块拖动排序")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "plateId1", value = "拖拽体"),
            @ApiImplicitParam(name = "plateId2", value = "参照体"),
            @ApiImplicitParam(name = "type", value = "实现类型1交换位置2挤压位置")
    })
    @PostMapping("plateSort")
    public ServiceResult<Object> plateSort(@RequestParam @NotNull Integer plateId1,
                                           @RequestParam @NotNull Integer plateId2,
                                           @RequestParam @NotNull @Max(2) @Min(1) Integer type) {
        //元素原地拖动
        if (plateId1.equals(plateId2)) {
            return success();
        }

        LambdaQueryWrapper<TiebaPlate> wrapper = new LambdaQueryWrapper<>();
        if (type == 1) {
            //两个元素交换位置
            wrapper
                    .eq(TiebaPlate::getId, plateId1)
                    .or()
                    .eq(TiebaPlate::getId, plateId2);
            List<TiebaPlate> list = tiebaPlateService.list(wrapper);
            int x = list.get(0).getOrderNum();
            int y = list.get(1).getOrderNum();
            list.get(0).setOrderNum(y);
            list.get(1).setOrderNum(x);
            //将collect更新到数据库
            boolean result = tiebaPlateService.updateBatchById(list);
            Assert.isTrue(result, "服务器异常");

            return success();

        } else if (type == 2) {

            if (plateId1 < plateId2) {
                //将plateId1位置拖到plateId2位置下面
                wrapper
                        .between(TiebaPlate::getId, plateId1, plateId2);
                List<TiebaPlate> list = tiebaPlateService.list(wrapper);
                List<TiebaPlate> collect = list.stream().sorted(Comparator.comparingInt(TiebaPlate::getOrderNum)).collect(Collectors.toList());

                //排序标记
                int[] orderNums = collect.stream().mapToInt(TiebaPlate::getOrderNum).toArray();
                //将首位元素挪到末尾
                TiebaPlate first = collect.get(0);
                collect.remove(first);
                collect.add(first);

                //将集合元素和排序标记绑定
                for (int i = 0; i < orderNums.length; i++) {
                    collect.get(i).setOrderNum(orderNums[i]);
                }

                //将collect更新到数据库
                boolean result = tiebaPlateService.updateBatchById(collect);
                Assert.isTrue(result, "服务器异常");

                return success();
            } else {
                //将plateId2位置拖到plateId1前面
                wrapper
                        .between(TiebaPlate::getId, plateId2, plateId1);
                List<TiebaPlate> list = tiebaPlateService.list(wrapper);
                List<TiebaPlate> collect = list.stream().sorted(Comparator.comparingInt(TiebaPlate::getOrderNum)).collect(Collectors.toList());
                //排序标记
                int[] orderNums = collect.stream().mapToInt(TiebaPlate::getOrderNum).toArray();

                //将末尾元素追加到首位
                TiebaPlate last = collect.get(collect.size() - 1);
                collect.remove(last);
                Collections.reverse(collect);
                collect.add(last);
                Collections.reverse(collect);

                //将集合元素和排序标记绑定
                for (int i = 0; i < orderNums.length; i++) {
                    collect.get(i).setOrderNum(orderNums[i]);
                }

                //将collect更新到数据库
                boolean result = tiebaPlateService.updateBatchById(collect);
                Assert.isTrue(result, "服务器异常");

                return success();
            }
        }
        return failure();
    }

Jetbrains全家桶1年46,售后保障稳定

思路:如何优雅的实现数据置顶、置尾、交换、拖动排序? – 简书

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/215507.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • win10键盘锁住了怎么解决

    win10键盘锁住了怎么解决有win10系统用户在使用的时候,发现键盘被锁住了,导致无法使用,经过分析可能是不小心按到了键盘上的锁住键锁定键盘的快捷键笔记本电脑:Fn+Numlock键第一种方法:1、外接键盘,是否按过“Numlock”键,如果按过“Numlock”键,再次使用外接键盘按一次“Numlock”键,就会恢复正常了。(仅仅锁定或者解锁数字键盘)2、可以在电脑键盘中找到“Fn”键,这个键又被称为“第二功能键”,因为当你按下这个键,再去按另一个带有两种功能的键时,那个键就会出现第二种功能。3、再找到“F.

    2022年5月29日
    57
  • #转载 基于C#通过OPC UA/DA访问PLC学习网站

    #转载 基于C#通过OPC UA/DA访问PLC学习网站#转载#基于C#通过OPCUA/DA访问PLC学习网站今年刚入职的新手,第一次接触OPCUA、OPCDA、C#、PLC,全靠各种百度,经过一个多星期的摸索,基本算是刚入门吧,下面把学习过程中收藏的一些实用的文章和大家分享一下,绝对可以让你少走很多弯路。1.C#读写opcua服务器,浏览所有节点,读写节点,读历史数据,调用方法,订阅,批量订阅操作-dathlin2.C#OPCUA服务器OPCUA网关三菱西门子欧姆龙Modbus转OPCUA服务器可配置的OPCUA服务器网

    2022年10月18日
    0
  • Simple Automated Backups for MongoDB Replica Sets

    Simple Automated Backups for MongoDB Replica Sets

    2022年1月2日
    51
  • 基于DB4O的Java Map

    基于DB4O的Java MapJava的Map是大家最常用的一个容器接口,它通过灵活的key/value结构存储数据。因为Map的简单易用很多工程师喜欢大量使用Map存放数据。但是Map的数据是存放在内存中,大量的数据存在内存中,不只是造成Java系统内存遍历慢的隐忧,更加可能系统内存溢出。针对这个问题,我们重新利用DB4O实现Map的接口,利用DB4O的对象高效的物理存储特性来减轻Java的内存压力。

    2022年7月21日
    13
  • 二进制乘法除法运算_二进制的补码怎么算

    二进制乘法除法运算_二进制的补码怎么算二进制补码乘法除法1)二进制乘法(1)BinaryMultiplication)Binarynumberscanbemultipliedusingtwomethods,二进制数可以使用两种方法相乘,Papermethod:Papermethodissimilartomultiplicationofdecimalnumbersonpaper….

    2022年10月7日
    0
  • 实现ORACLE和SQL Server连接

    实现ORACLE和SQL Server连接

    2021年7月30日
    76

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号