• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

vue实现列表拖拽排序的功能

vue 搞代码 4年前 (2022-01-08) 46次浏览 已收录 0个评论

这篇文章主要介绍了vue实现列表拖拽排序的功能,帮助大家更好的理解和学习vue,感兴趣的朋友可以了解下

  在日常开发中,特别是管理端,经常会遇到要实现拖拽排序的效果;这里提供一种简单的实现方案。

  此例子基于vuecli3

首先,我们先了解一下js原生拖动事件:

  在拖动目标上触发事件 (源元素):

  • ondragstart – 用户开始拖动元素时触发
  • ondrag – 元素正在拖动时触发
  • ondragend – 用户完成元素拖动后触发  

  释放目标时触发的事件:

  • ondragenter – 当被鼠标拖动的对象进入其容器范围内时触发此事件
  • ondragover – 当某被拖动的对象在另一对象容器范围内拖动时触发此事件
  • ondragleave – 当被鼠标拖动的对象离开其容器范围内时触发此事件
  • ondrop – 在一个拖动过程中,释放鼠标键时触发此事件

 基于js的原生拖拽事件,本次实现的拖拽排序的原理大概是:鼠标按住列表某一项开始拖动时触发ondragstart事件,将该拖动项用变量记录下来;

接着拖拽过程中,该拖动项经过列表其他项时,触发ondragenter事件,同样记录该拖动项最后经过的列表其他项的数据,最后在ondragend 事件中

将数组列表删掉一开始ondragstart事件记录的拖动项,并将删掉的数据插入ondragenter事件最后记录的位置,完成拖动排序。

 具体代码如下:

  <div class="test_wrapper">  <div class="sort-item"> {{ item.label }} </div></div>

另外

  为了实现拖动的动画效果,本文来源gaodaimacom搞#代%码@网-这里用到了transition-group组件,如上面代码显示,将transition-group组件的属性name设为‘sort’;并添加以下代码;

 .sort-move { transition: transform 0.3s; }

       注意:为了让transition有效果出现,v-for渲染的数据列表必须有key属性,且该key属性不可设为index; 

最终效果如下:

以上就是vue实现列表拖拽排序的功能的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:vue实现列表拖拽排序的功能

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址