vue.draggable实现表格拖拽排序效果

主要使用vuedraggable和sortablejs两个组件。

1、安装组件

npm install vuedraggable npm install sortablejs

2、引入组件

import draggable from 'vuedraggable'; import Sortable from 'sortablejs'; export default { components: { draggable, Sortable }, ....

3、HTML

我的例子是给表格排序,项目整体使用的是ivew,所以用了ivew的栅格来画表格

<Row> <Col span="1">序号</Col> <Col span="2">商品条码</Col> <Col span="3">商品名称</Col> <Col span="1">单位</Col> </Row> <draggable v-model="tableData" :options="{draggable:'.rows'}" :move="getdata" @update="datadragEnd"> <Row v-for="(item,index) in tableData" :key="index"> <Col span="1"> <div>{{index+1}}</div> </Col> <Col span="2"> <div>{{item.barCode}}</div> </Col> <Col span="2"> <div>{{item.name}}</div> </Col> <Col span="2"> <div>{{item.unit}}</div> </Col> </Row> </draggable>

options中draggable的值是拖动的class。一开始怎么都不能拖动,加上这个就可以了。

4、两个方法

move:拖动中
update:拖拽结束

getdata (data) { // console.log('getdata方法'); }, datadragEnd (evt) { // console.log('datadragEnd方法'); console.log('拖动前的索引 :' + evt.oldIndex) console.log('拖动后的索引 :' + evt.newIndex) }

表格的处理逻辑是:
1、当前行的id和排序号作为参数,调用后台更改顺序的方法
2、不论调用成功与否,都重新渲染表格数据

【注意】如果有分页,那么传给后台的排序号就要再加上之前的条数,即(页码-1)*每页条数

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/03436b081bd59229dcc025c9f633bfe5.html