vuedraggable+element ui实现页面控件拖拽排序效果


Posted in Javascript onJuly 29, 2020

项目要实现一些控件的拖拽排序。从而找到了这款vuedraggable控件,供大家参考,具体内容如下

vuedraggable+element ui实现页面控件拖拽排序效果

如上图要实现这些控件的拖拽排序
这是拖拽后

vuedraggable+element ui实现页面控件拖拽排序效果

由于公司网络的原因,项目没有使用npm,都是使用的引入的js

<script type="text/javascript" src="lib/sortable/Sortable.min.js"></script>
<script type="text/javascript" src="lib/vuedraggable/vuedraggable.min.js"></script>

布局代码

<el-form :inline="true">
     <draggable v-model="filters" dragable="true" :move="getdata" @update="datadragEnd">
      <transition-group>
       <el-col :span="8" v-for="filter in filters" :key="filter.filterKey" style="margin-top: 5px">
        <el-form-item :label="filter.name" >
         <el-input v-model="filter.displayName" placeholder="请输入设置属性" @focus="openFilterDialog(filter)"></el-input>
        </el-form-item>
       </el-col>
      </transition-group>
     </draggable>
     <fitlerdialog v-bind:visable=dialogObjectVisible v-bind:avtivefilter=avtivefilter v-on:on-filter-data-change="onFilterDataChange" v-on:filterdialogcancle="handleDialogObjectcancle" v-on:filterdialogclose="handleDialogObjectClose"></fitlerdialog>
</el-form>

标签draggable放在你要拖拽的组件的最外层。

相关的处理代码

getdata(evt) {
 console.log(evt.draggedContext.filterKey)
 //这里evt.draggedContext后续的内容根据具体的定义变量而定
},
datadragEnd(evt) {
 console.log('拖动前的索引 :' + evt.oldIndex)
 console.log('拖动后的索引 :' + evt.newIndex);

 let filters = this.filters;
 for(let a=0;a<filters.length;a++){
  filters[a].index = a;
 }
 vm.report.filter = filters;

}

这里是因为我们需要将每个的顺序记录下来所以有业务代码。
每次移动后,可以通过v-model获取所有的控件,他们的顺序是当前排好的顺序,再进行index顺序记录。

evt为object,他的内容较多。

vuedraggable+element ui实现页面控件拖拽排序效果

draggedContext: 被拖拽元素的上下文

index:拖拽元素的指针
element: 拖拽数据本身
futureIndex: 拖动后的index

element如图:

vuedraggable+element ui实现页面控件拖拽排序效果

这是filters定义的数据本身也就是v-model内容。

relatedContext: 拖入区域的上下文

index: 目标元素的index
element:目标数据本身
list: 拖入的列表
component:目标组件

dragged:被拖拽元素的指向

大概就这些,功能较简单,但满足了要求就行。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript绝句欣赏 一些经典的js代码
Feb 22 Javascript
node.js中的http.response.setHeader方法使用说明
Dec 14 Javascript
详解javascript事件冒泡
Jan 09 Javascript
JavaScript知识点总结之如何提高性能
Jan 15 Javascript
详解JavaScript表单验证(E-mail 验证)
Mar 31 Javascript
微信小程序scroll-view实现横向滚动和上拉加载示例
Mar 06 Javascript
浅谈使用mpvue开发小程序需要注意和了解的知识点
May 23 Javascript
Element UI框架中巧用树选择器的实现
Dec 12 Javascript
Node.js 实现远程桌面监控的方法步骤
Jul 02 Javascript
Element-UI+Vue模式使用总结
Jan 02 Javascript
js数组相减简单示例【删除a数组所有与b数组相同元素】
Mar 04 Javascript
JS中类的静态方法,静态变量,实例方法,实例变量区别与用法实例分析
Mar 14 Javascript
Vue组件Draggable实现拖拽功能
Dec 01 #Javascript
BootStrap modal实现拖拽功能
Dec 01 #Javascript
vuejs2.0运用原生js实现简单拖拽元素功能
Aug 21 #Javascript
BootStrap table实现表格行拖拽效果
Dec 01 #Javascript
一次Webpack配置文件的分离实战记录
Nov 30 #Javascript
基于Vue组件化的日期联动选择器功能的实现代码
Nov 30 #Javascript
vue拖拽排序插件vuedraggable使用方法详解
Aug 21 #Javascript
You might like
晶体管来复再生式二管收音机
2021/03/02 无线电
php include,include_once,require,require_once
2008/09/05 PHP
THREE.JS入门教程(6)创建自己的全景图实现步骤
2013/01/25 Javascript
html dom节点操作(获取/修改/添加或删除)
2014/01/23 Javascript
node.js中的http.createServer方法使用说明
2014/12/14 Javascript
JavaScript 判断一个对象{}是否为空对象的简单方法
2016/10/09 Javascript
巧用Vue.js+Vuex制作专门收藏微信公众号的app
2016/11/03 Javascript
AngularJS实现用户登录状态判断的方法(Model添加拦截过滤器,路由增加限制)
2016/12/12 Javascript
vue2 中如何实现动态表单增删改查实例
2017/06/09 Javascript
elementUI中Table表格问题的解决方法
2018/12/04 Javascript
微信小程序生成二维码的示例代码
2019/03/29 Javascript
jQuery事件blur()方法的使用实例讲解
2019/03/30 jQuery
ES6 Set结构的应用实例分析
2019/06/26 Javascript
小程序组件传值和引入sass的方法(使用vant Weapp组件库)
2020/11/24 Javascript
[02:53]DOTA2英雄昆卡基础教程
2013/11/25 DOTA
[06:07]辉夜杯现场观众互动 “比谁远送显示器”
2015/12/26 DOTA
[00:36]我的中国心——Serenity vs Fnatic
2018/08/21 DOTA
在Linux系统上通过uWSGI配置Nginx+Python环境的教程
2015/12/25 Python
5分钟 Pipenv 上手指南
2018/12/20 Python
Django框架视图介绍与使用详解
2019/07/18 Python
python Tensor和Array对比分析
2020/01/08 Python
tensorflow 固定部分参数训练,只训练部分参数的实例
2020/01/20 Python
python字符串下标与切片及使用方法
2020/02/13 Python
keras绘制acc和loss曲线图实例
2020/06/15 Python
Canvas实现贝赛尔曲线轨迹动画的示例代码
2019/04/25 HTML / CSS
荷兰之家英文站:Holland at Home
2016/10/26 全球购物
PHP如何自定义函数
2016/09/16 面试题
.NET里面什么时候需要调用垃圾回收
2015/06/01 面试题
标准毕业生自荐信范文
2013/11/04 职场文书
工商管理系学生的自我评价分享
2013/11/29 职场文书
生产操作工岗位职责
2014/09/16 职场文书
党员教师学习党的群众路线教育实践活动心得体会
2014/10/31 职场文书
关于长城的导游词
2015/01/30 职场文书
离婚律师函范本
2015/05/27 职场文书
员工给公司的建议书
2019/06/24 职场文书
Java 多线程协作作业之信号同步
2022/05/11 Java/Android