利用Vue-draggable组件实现Vue项目中表格内容的拖拽
网络编程 2021-07-04 15:50www.168986.cn编程入门
这篇文章主要介绍了利用Vue-draggable组件实现Vue项目中表格内容的拖拽排序,长沙网络推广觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
Vue-draggable 的github传送门 :
一. 下载依赖包npm install vuedraggable -S
二. 在需要使用的当前界面引入依赖,注册组件
import draggable from "vuedraggable"; export default { ponents: { draggable, }
三. 在template 中建立表格,分别写出thead 部分不变, 此处需要将draggable 渲染成tbody,不然draggable会被解析成div 影响样式。
(渲染方法<draggable v-model="tablelist" element="tbody">)
<table class="dataTabble"> <thead> <tr> <th width="110">栏目名称</th> <th width="200">发布时间</th> <th width="160">公告数量</th> <th width="160">操作</th> </tr> </thead> <draggable v-model="tablelist" element="tbody" :move="getdata" @update="datadragEnd"> <tr v-for="(item,id) in tablelist" :key="id"> <td>{{item.name}}</td> <td>{{item.time}}</td> <td>{{item.num}}</td> <td> <div class="tabopa"> <a @click="dialogFormVisible = true" style="cursor:pointer">添加</a> <a @click="open2">删除</a> </div> </td> </tr> </draggable> </table> <div class="zhu mt40">提示拖动可对栏目进行排序</div>
此处data部分,通过{ { } } 获取data中数据,实际中通过请求获取
data() { return { tablelist: [ { id: 1, name: "活动消息1", time: "2018-08-25 1454", num: "1000" }, { id: 2, name: "公司消息2", time: "2018-08-25 1454", num: "200" }, { id: 3, name: "个人消息3", time: "2018-08-25 1454", num: "30000" }, { id: 4, name: "客户消息4", time: "2018-08-25 1454", num: "40" } ], }; },
四.相关方法
获取拖动中和拖动结束时的id
methods: { //拖动中与拖动结束 getdata(evt) { console.log(evt.draggedContext.element.id); }, datadragEnd(evt) { console.log("拖动前的索引 :" + evt.oldIndex); console.log("拖动后的索引 :" + evt.newIndex); console.log(this.tags); },
五.贴出全部代码
<template> <div> <!--main--> <table class="dataTabble"> <thead> <tr> <th width="110">栏目名称</th> <th width="200">发布时间</th> <th width="160">公告数量</th> <th width="160">操作</th> </tr> </thead> <draggable v-model="tablelist" element="tbody" :move="getdata" @update="datadragEnd"> <tr v-for="(item,id) in tablelist" :key="id"> <td>{{item.name}}</td> <td>{{item.time}}</td> <td>{{item.num}}</td> <td> <div class="tabopa"> <a @click="dialogFormVisible = true" style="cursor:pointer">添加</a> <a @click="open2">删除</a> </div> </td> </tr> </draggable> </table> <div class="zhu mt40">提示拖动可对栏目进行排序</div> <!--main end--> </div> </template> <script> import draggable from "vuedraggable"; export default { ponents: { draggable, }, data() { return { tablelist: [ { id: 1, name: "活动消息1", time: "2018-08-25 1454", num: "1000" }, { id: 2, name: "公司消息2", time: "2018-08-25 1454", num: "200" }, { id: 3, name: "个人消息3", time: "2018-08-25 1454", num: "30000" }, { id: 4, name: "客户消息4", time: "2018-08-25 1454", num: "40" } ], }; }, methods: { //拖动中与拖动结束 getdata(evt) { console.log(evt.draggedContext.element.id); }, datadragEnd(evt) { console.log("拖动前的索引 :" + evt.oldIndex); console.log("拖动后的索引 :" + evt.newIndex); console.log(this.tags); }, } } </script> <style> </style>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程