我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue 结合Sortablejs实现table行排序功能

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue 结合Sortablejs实现table行排序功能

Sortable.js是一款轻量级的拖放排序列表的js插件(虽然体积小,可是功能很强大)

官方Demo:http://rubaxa.github.io/Sortable/

场景

在一个列表展示页面上,使用了表格组件,原有组件本身不支持拖拽功能,需求要求在列表的基础上支持行拖拽排序。因此引入了www.sortablejs.com插件。

问题

引入Sortablejs后刚开始都很顺利,效果的拖拽基本功能效果已实现。代码如下

const tbody = this.$refs.Scheduling.querySelectorAll('.ant-table-tbody') // 元素选择器名称根据实际内容替换
Sortable.create(tbody[0]) //具体Sortablejs的api文档可查看官网

下一步就是保存数据
但是在保存数据的时候才发现,数据并没有修改,还是原来的数据,接下来就来处理数据排序的问题,经查看Sortablejs文档引入了onEnd方法,也可用onUpdate方法
代码修改如下

 const tbody = this.$refs.Scheduling.querySelectorAll('.ant-table-tbody') // 元素选择器名称根据实际内容替换
  const _this = this
    Sortable.create(tbody[0], {
      onEnd({ newIndex, oldIndex }) {
      const currRow = _this.databases.splice(oldIndex, 1)[0]
      _this.databases.splice(newIndex, 0, currRow)
      }
    })

修改完之后本以为可以了,就去调试一下,就出现了比较诡异的问题。A和B拖拽交换位置之后,B和A又神奇的换回去了,整体都乱套了!很奇怪。
经查看资料才发现
Vue的实现原理,在Vue2.0之前是通过defineProperty依赖注入和跟踪的方式实现双向绑定。针对v-for数组指令,如果指定了唯一的Key,则会通过高效的Diff算法计算出数组内元素的差异,进行最少的移动或删除操作。而Vue2.0之后在引入了Virtual Dom之后,Children元素的Dom Diff算法和前者其实是相似的,唯一的区别就是,2.0之前Diff直接针对v-for指令的数组对象,2.0之后则针对Virtual Dom。DOM Diff算法在这里不再赘述,这里解释的比较清楚virtual-dom diff算法
假设我们的列表元素数组是[‘A','B','C','D']
渲染出来后的DOM节点是[$A,$B,$C,$D]
那么Virtual Dom对应的结构就是[{elm:$A,data:'A'},
{elm:$B,data:'B'},
{elm:$C,data:'C'},
{elm:$D,data:'D'}]
假设拖拽排序之后,真实的DOM变为[$B,$A,$C,$D]
此时我们只操作了真实DOM,改编了它的位置,而Virtual Dom的结构并没有改变,依然是[{elm:$A,data:'A'},
{elm:$B,data:'B'},
{elm:$C,data:'C'},
{elm:$D,data:'D'}]
此时我们把列表元素也按照真实DOM排序后变成[‘B','A','C','D']
这时候根据Diff算法,计算出的Patch为,VNode前两项是同类型的节点,所以直接更新,即把$A节点更新成$B,把$B节点更新成$A,真实DOM又变回了[$A,$B,$C,$D]
所以就出现了拖拽之后又被Patch算法更新了一次的问题,操作路径可以简单理解为
拖拽移动真实DOM -> 操作数据数组 -> Patch算法再更新真实DOM
根本原因
根本原因是Virtual DOM和真实DOM之间出现了不一致。
所以在Vue2.0以前,因为没有引入Virtual DOM,这个问题是不存在的。
在使用Vue框架的时候要尽量避免直接操作DOM

最后修改代码如下

 onEnd({ newIndex, oldIndex }) {
         const currRowdom = tbody[0].children[newIndex]
         const oldRowdom = tbody[0].children[oldIndex]
         tbody[0].removeChild(currRowdom)
         if (newIndex > oldIndex) {
          tbody[0].insertBefore(currRowdom, oldRowdom)
        } else {
          tbody[0].insertBefore(currRowdom, oldRowdom.nextSibling)
        }

        const currRow = _this.databases.splice(oldIndex, 1)[0]
        _this.databases.splice(newIndex, 0, currRow)
        }

到此这篇关于Vue 结合Sortablejs实现table行排序 的文章就介绍到这了,更多相关vue table行排序 内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue 结合Sortablejs实现table行排序功能

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue 结合Sortablejs实现table行排序功能

在一个列表展示页面上,使用了表格组件,原有组件本身不支持拖拽功能,需求要求在列表的基础上支持行拖拽排序,因此引入了www.sortablejs.com插件,接下来通过本文给大家讲解Vue 结合Sortablejs实现table行排序功能,需要的朋友可以参考下
2022-11-13

PHP实现排序功能总结

本篇文章给大家带来了关于PHP的相关知识,其中主要介绍了关于排序功能的相关问题,通过实例完成php+mysqli排序功能的实现,下面一起来看一下,希望对大家有帮助。和大家一起完成php+mysqli排序功能的实现.一、sql:-- phpMyAdmin SQL Dump-- version 4.5.1-- http://www.phpmyadmin.net---- Host: 127.0.0.1--
2022-06-20

layui table数据排序与筛选功能的实现(layui table实现数据排序与筛选功能的步骤)

layui数据排序与筛选功能实现利用layuitable插件,实现数据的排序和筛选功能,提升数据展示的灵活性。文章详细介绍了功能实现步骤:安装layui:下载layui库并引入至HTML页面。初始化table:创建表格结构,使用layuiAPI初始化table实例。实现排序:启用sort选项,指定排序规则。实现筛选:添加filter属性,指定筛选条件。处理事件:处理table的sort和filter事件,更新数据源并重新渲染table。文章还提供了示例代码和注意事项,帮助开发者快速上手。
layui table数据排序与筛选功能的实现(layui table实现数据排序与筛选功能的步骤)
2024-04-02

Vue中怎么实现动态表格的排序功能

这篇文章主要介绍“Vue中怎么实现动态表格的排序功能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue中怎么实现动态表格的排序功能”文章能帮助大家解决问题。首先,为了实现动态表格的排序,我们需要一
2023-07-06

Redis实现排行榜及相同积分按时间排序功能的实现

目录不考虑积分相同积分相同按时间排序,排名唯一设计1设计2积分相同按时间排序,并列排名在日常的开发中,经常会碰到需要对用户的分值等进行排序,比如在游戏里面需要对战斗力进行排行,在组队活动中需要对各个队伍的贡献值进行排行,在微信中需要对各个好
2022-08-22

Vue实用功能之实现拖拽元素、列表拖拽排序

在日常开发中,特别是管理端,经常会遇到要实现拖拽排序的效果,下面这篇文章主要给大家介绍了关于Vue实用功能之实现拖拽元素、列表拖拽排序的相关资料,需要的朋友可以参考下
2022-11-13

Vue组件设计之多列表拖拽交换排序功能实现

这篇文章主要介绍了Vue组件设计之多列表拖拽交换排序,常见的场景有单列表拖拽排序,多列表拖拽交换排序,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-18

如何结合PHP和Vue实现员工考勤的请假审批记录功能

随着信息技术的快速发展,越来越多的企业开始采用电子化的方式管理员工的考勤和请假审批记录。PHP作为一种广泛使用的后端开发语言,具有高效、稳定和易于扩展等优点。而Vue作为一种流行的前端框架,能够方便地实现良好的用户界面和交互效果。本文将介绍
2023-10-21

使用任务计划功能结合shutdown命令让Win7实现定时自动执行

大家在使用电脑的时候可能会遇到一些需要无人值守让电脑自行执行任务后定时关机的情形,在Win7系统中,我们可以使用“python任务计划”设置功能结合shutdown命令灵活设置任务计划,让Win7系统实现定时自动执行
2023-06-04

VUE 路由与懒加载结合,优化应用程序性能,实现更好的用户体验

本文将探讨 Vue 路由与懒加载相结合的应用方法,介绍如何通过懒加载优化应用程序性能,并提高用户体验。
VUE 路由与懒加载结合,优化应用程序性能,实现更好的用户体验
2024-02-05

编程热搜

目录