使用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

相关内容

热门资讯

广西宁明:AI+低空经济赋能 ... 转自:新华财经日前,“人工智能赋能县域经济高质量发展院士专家宁明行”活动暨广西人机交互与智能决策重点...
视频丨转发周知!春运火车票今起... 今天(1月19日)春运第一天火车票开售哪天可买春节假期第一天的车票?2026年春运购票有哪些新变化?...
钨金属原料价格持续上涨,翔鹭钨... (来源:财闻) 预计归属于上市公司股东的净利润为1.25亿元~1.8亿元,...
网友:为什么飞船必须有舷窗 转... #神20舷窗裂纹维修细节披露#【网友:#为什么飞船必须有舷窗#[思考]转存长知识!】今天,#神20飞...
监管对“投资大V”出手,收割粉... 财联社1月19日讯(记者 吴雨其)在许多普通投资者眼里,社交平台上的“实盘冠军”、“投资大V”,似乎...