使用Vue.Draggable的自定义拖拽表单是如何实现的
创始人
2024-05-31 02:20:44

Vue.Draggable 是一款基于 Sortable.js 实现的 vue 拖拽插件,实现组件化的思想,可以结合 Vue,使用起来更方便

// NPM 或 yarn 安装方式yarn add vuedraggablenpm i -S vuedraggable
import draggable from 'vuedraggable';
components: {draggable
}
属性名称说明
group:group= “name”,相同的组之间可以相互拖拽
sort:sort= “true”,是否开启内部排序,如果设置为 false,它所在组无法排序,在其他组可以拖动排序
animation拖动时的动画效果,数字类型。如设置 animation=1000 表示 1 秒过渡动画效果

如果是单列拖拽用 group="people"

vue.draggable group 拖拽分组多组之间相互拖拽,可以实现不同数组之间相互拖拽。
比如 group 都为 componentsGroup 的组之间可以相互拖动,本文例子中 A 列和 B 列可以相互拖动,但是无法拖到 C 列。

设置方式,object,也可以通过自定义函数 function 实现复杂的逻辑

  group:{name:'componentsGroup',//组名为 itxstpull: true|false| 'clone'|array|function,//是否允许拖出当前组put:true|false|array|function,//是否允许拖入当前组
}

vue.draggable 全部事件列表

vue.draggable 拖拽时会触发各种事件,比如 start, add, remove, update, end, choose, unchoose, sort, filter, clone 事件,本文将列出 vue.draggable 的全部事件。

事件列表

事件名称说明
start开始拖动时触发的事件
add从一个数组拖拽到另外一个数组时触发的事件
remove移除事件
update拖拽变换位置时触发的事件
end拖拽完成时的事件
choose鼠标点击选中要拖拽元素时的事件
unchoose选中后松开鼠标的事件
sort位置变化时的事件
clone从一个数组拖拽到另外一个数组时触发的事件和 add 不同,clone 是复制了数组元素

网站参考:
vue.draggable 中文文档
✨Element UI 表单设计及代码生成器

代码参考:

{{ item.label }}
computed:{fieldListTheDisplayOfTheSameElement() {return function(array) {return this.fieldList.filter(item => {return array.includes(item.valType);});};}
}
computed:{fieldListTheDisplayOfTheSameElement() {return function(array) {return this.fieldList.filter(item => {return array.includes(item.valType);});};}
}
xxxxx内容展示xxxxx

相关内容

热门资讯

唠着家常送政策 (来源:衢州日报)转自:衢州日报  记者 徐敏 通讯员 林夏宁  “大婶,快坐!2026年城乡居民医...
智造新城“薪立方”5天解“薪”... (来源:衢州日报)转自:衢州日报  本报讯 (记者 方俊 报道组 周毅辉 通讯员 柯元哲 江剑) “...
重庆22人保送清北 11月30日,随着第41届全国中学生数学奥林匹克竞赛(决赛)落下帷幕,2025年度全国五大学科竞赛国...
贯彻落实党的二十届四中全会精神... 12月2日至3日,市委书记袁家军前往长寿区、梁平区、垫江县,调研经济运行、保障和改善民生、灾后恢复重...
忒斯特酿造上新“山色”啤酒 (来源:衢州日报)转自:衢州日报  本报讯 (通讯员 柴奇超 郑召隆) 近日,笔者来到忒斯特酿造(常...