时间:2021-05-26
背景
1、vue项目中的表格需要实现行拖拽功能
2、表格使用element组件库中el-table
方案介绍
Sortable.js
介绍:Sortable.js是一款轻量级的拖放排序列表的js插件
引用自官方文档:No jQuery required. Supports Meteor, AngularJS, React, Polymer, Vue, Knockout and any CSS library, e.g. Bootstrap.
参考地址:https://github.com/SortableJS/Sortable
vuedraggable
介绍:基于Sortable.js的vue组件,用以实现拖拽功能
引用自官方文档:Vue drag-and-drop component based on Sortable.js
参考地址:https://github.com/SortableJS/Vue.Draggable
遇到的问题
在使用vuedraggable的过程中,发现必须用<draggable></draggable>包裹拖动项的父级元素,但是element组件库对table进行封装,无法直接包裹拖动项(即tr)的父级元素
如果你的项目中,表格未使用组件库,实现可以参考https://ponents: { Sortable }})
步骤三: el-table 添加row-key属性
<el-table ref="filterTable" row-key="ip" @filter-change="handlerFilterChange" class="cl-table" :data="resourceList" v-loading="resourceListLoading" stripe style="width:100%;"> <el-table-column prop="name" label="主机名" :min-width="150" show-overflow-tooltip> </el-table-column> </el-table>步骤四 : 将拖拽元素设置为要拖动项的父级元素
mounted() { // 表格中需要实现行拖动,所以选中tr的父级元素 const table = document.querySelector('.el-table__body-wrapper tbody') const self = this Sortable.create(table, { onEnd({ newIndex, oldIndex }) { console.log(newIndex, oldIndex) const targetRow = self.resourceList.splice(oldIndex, 1)[0] self.resourceList.splice(newIndex, 0, targetRow) } }) }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言:前天刚写了篇JS组件BootstrapTable表格行拖拽效果,今天接到新的需要,需要在之前表格行拖拽的基础上能够同时拖拽选中的多行。用了半天时间研究了下
本文给大家介绍vue使用sortable实现el-table拖拽排序功能,具体内容如下所示:npm下载:npminstallsortablejs--save引入
本文介绍了Vue+element-ui实现表格的分页功能示例,分享给大家,具体如下:实现效果如下图所示:template部分:数据部分:获取测试的数据(19个)
element-ui对话框可拖拽及边界处理应业务需求,需要实现对话框可拖拽问题,应element-ui没有提供官方支持,于是便参考大神的文章,得出了适合业务需要
Draggable为基于Sortable.js的vue组件,用以实现拖拽功能。具体说明,请参考:学习链接npm官方演示:vuedraggable特性:支持触摸设