js 多选框里的元素拖动排序

本文介绍了一个项目需求,即在多选框中实现已选择值的手动拖动排序。通过在生成的`<li>`元素中添加`draggable="true"`属性来启用拖动效果,并在初始化时监听拖动事件。拖动完成后需注意顺序更新及请求反馈的处理,确保显示顺序与下拉列表一致。此外,文章提供了Vue框架下的核心代码示例,实现了元素的拖动监听和处理逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、需求背景:

               项目要求在多选的情况下对已选择的值进行手动拖动排序

二、设计分析:

               我们正常的js插件中没有此功能,需要拖动里面的元素,就需要添加在生成的已选择的li元素里添加h5属性(draggable="true"),这样我们才能有拖动元素的这个效果。然后我们在select初始化的页面再监听拖动事件。除了核心的拖动外,我们还需要注意两件事,一件事是拖动完毕后发送请求后的再次修改操作,这要求返回的值我们要按照顺序显示上去,因为使用过select相关插件的都知道,默认显示值得顺序跟下拉列表的顺序有关系,其次就是如果我们需要根据某些条件需要改变下拉框里的值,需要关注默认值是否在下拉框中,如果没有需要剔除。

三、示意图

 

四、核心代码

  1. 我们需要在插件中找到生成已选择值得HTML,加上draggable="true"的属性,让元素可以拖动(这个是我使用插件源代码,在里面添加此属性)
  2. 添加拖动事件的监控,并写好监控事件的处理逻辑(代码是vue框架,只参照核心js就好了)
     this.$nextTick(function () {
              
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值