资讯专栏INFORMATION COLUMN

通过拖动列表,重新获取列表的排序

whinc / 1793人阅读

摘要:文章首发在我的个人博客上有这样一个列表需要拖动列表,改变顺序,并把新的顺序保存下来传给后端。实现实现方法如下是当前元素下标,是拖动到的位置下标。

文章首发在我的 个人博客上

有这样一个列表:

需要拖动列表,改变顺序,并把新的顺序保存下来传给后端。

实现实现方法如下:

function arrSort(arr,oldIndex,newIndex){
  //  oldIndex是当前元素下标,newIndex是拖动到的位置下标。

  //如果当前元素在拖动目标位置的下方(即把该元素向上拖),
  //先给数组中元素拖动到的地方(即索引为newIndex的位置)新增一个和当前拖动元素值一样的元素,
  //然后再把数组中之前的那个拖动的元素删除掉,因为前面插入了一个元素,所以数组长度要+1
  if(oldIndex > newIndex){
    arr.splice(newIndex,0,arr[oldIndex]);
    arr.splice(oldIndex+1,1)
  } else {
  //如果当前元素在拖动目标位置的上方(即把该元素向下拖),
  //同样,给数组newIndex+1的地方新增一个和当前元素值一样的元素,
  //这时,将之前的那个拖动的元素删除掉,索引不变,还是oldIndex
    arr.splice(newIndex+1,0,arr[oldIndex]);
    arr.splice(oldIndex,1)
  }
}

最终总结就一句话:先在新的位置添加一个元素,然后再把原来的元素删掉!

至于如何获得 ==newIndex== 和 ==oldIndex== ?

我们项目使用的vue,这个拖拽用的一个库:Vue.Draggable,

通过这个组件提供的方法,就能同时获取newIndex和oldIndex;

其他方法:++拖拽前、后 都遍历下这个列表,应该也能拿到列表中元素的排序++该方法未尝试

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/104703.html

相关文章

  • 拖放排序插件Sortable.js

    摘要:介绍是一款轻量级的拖放排序列表的插件虽然体积小,但是功能很强大下载地址官方特点支持触屏设备和大部分浏览器以下的就不支持了,原因都懂得可以从一个列表容器中拖拽一个列表单元到其他容器或本列表容器中进行排序移动列表单元时有动画支持拖放操作和可选择 介绍 Sortable.js是一款轻量级的拖放排序列表的js插件(虽然体积小,但是功能很强大)下载地址:https://github.com/Ru...

    tomorrowwu 评论0 收藏0
  • 用两种不同姿势来实现拖动排序

    摘要:前言鲁迅说过如果你的技术不好,那么你的姿势要多。元素不是被拖动目标时。先实现拖动的效果,大概就是这样在的时候记下必要的信息将小强的改成在记录下鼠标在轴上移动的距离,横行的话就是这样基本的拖动问题是解决了,元素最起码是可以拖动起来了。 前言 鲁迅说过:如果你的技术不好,那么你的姿势要多。 showImg(https://segmentfault.com/img/bVZSnT?w=500&...

    paney129 评论0 收藏0
  • 用两种不同姿势来实现拖动排序

    摘要:前言鲁迅说过如果你的技术不好,那么你的姿势要多。元素不是被拖动目标时。先实现拖动的效果,大概就是这样在的时候记下必要的信息将小强的改成在记录下鼠标在轴上移动的距离,横行的话就是这样基本的拖动问题是解决了,元素最起码是可以拖动起来了。 前言 鲁迅说过:如果你的技术不好,那么你的姿势要多。 showImg(https://segmentfault.com/img/bVZSnT?w=500&...

    zsy888 评论0 收藏0

发表评论

0条评论

whinc

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<