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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Linux磁盘简介「建议收藏」

    Linux磁盘简介「建议收藏」转载请标明出处:http://blog.csdn.net/forezp/article/details/94174577本文出自方志朋的博客个人博客纯净版:https://www.fangzhipeng.com/db/2019/09/10/linux-disc.html本文主要从以下几个方面介绍Linux磁盘:磁盘的接口硬盘的设备名称文件系统RAID独立冗余磁盘阵列磁盘…

    2022年5月28日
    38
  • java新手代码大全实例,深度解析,值得收藏

    java新手代码大全实例,深度解析,值得收藏策略1——停止挖掘LawofHoles是说当自己进洞就应该停止挖掘。对于单体式应用不可管理时这是最佳建议。换句话说,应该停止让单体式应用继续变大,也就是说当开发新功能时不应该为旧单体应用添加新代码,最佳方法应该是将新功能开发成独立微服务。如下图所示:除了新服务和传统应用,还有两个模块,其一是请求路由器,负责处理入口(http)请求,有点像之前提到的API网关。路由器将新功能请求发送给新开发的服务,而将传统请求还发给单体式应用。另外一个是胶水代码(gluecode),将微服务和单体应用集

    2022年6月21日
    38
  • 指令字长,机器字长,存储字长的关系_指令字长的概念

    指令字长,机器字长,存储字长的关系_指令字长的概念指令字长、存储字长、机器字长、时钟周期、机器周期、指令周期、取址周期、存取周期的关系考研做题途中遇到这些问题,发现自己掌握的很模糊,遂写下此篇,加深记忆。1、机器字长、存储字长、指令字长机器字长:CPU一次能够处理的数据的位数。通常等于寄存器的位数。例子:windows64位/32位,这里的64位和32位指的就是该操作系统的机器字长。存储字长:计算机存储器中一个存储单元可以存储的位数。例子:某某计算机按照字节编址,即说明该计算机的存储字长为1B=8位。指令字长:计算机内一条指令的位数。这里通常指

    2022年8月31日
    0
  • C语言分苹果_数据结构:使用C语言

    C语言分苹果_数据结构:使用C语言1、题目描述果园里有堆苹果,N(1<N<9)只熊来分。第一只熊把这堆苹果平均分为N份,多了一个,它把多的一个扔了,拿走了一份。第二只熊把剩下的苹果又平均分成N份,又多了一个,它同样把多的一个扔了,拿走了一份,第三、第四直到第N只熊都是这么做的,问果园里原来最少有多少个苹果?示例和说明如下:2、解题思路我的方法很简单就是从最小的可能的数开始,一个一个尝试,满足了测试的要求之后

    2022年10月10日
    1
  • Response.ContentType 所有类型

    Response.ContentType 所有类型ez=>application/andrew-inset,hqx=>application/mac-binhex40,cpt=>application/mac-compactpro,doc=>application/msword,bin=>application/octet-stream,dms=>applicatio

    2022年7月19日
    11
  • 八个Android项目源码

    八个Android项目源码给大家分享几个Android开发项目源码,大部分功能相信可以在实战项目中直接使用,供大家下载学习,大部分项目是基于AndroidStudio开发,IDE为Eclipse的童鞋可通过网上教程自行转换,这里就不多说了。有句话说,不贴墙纸的装修都是耍流氓,无源码无效果图的文章也算是耍流氓,尴尬,那就直接上图吧。最近在整理GitHub,打算把一些以前做过的项目中部分功能和使用的技术点资料上传,回头也和大家分享。OK,要去忙了,再不去忙项目,测试版出不来就危险了,希望有一天不用敲代码也可以吃到馒头,吼吼~~

    2022年6月6日
    31

发表回复

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

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