Vue.Draggable

需求:多个列表中实现拖动
代码:

<div class="groupingMain-item"  v-for="(item, index) in row" :key="index">
 <draggable
  @end="end"
  :id="index"
  :list="item"
  :options="{group:{name: 'people'},chosenClass: 'el-tag--success'}"      
  class="groupingMain-item-tags" >
  ... 
 </draggable>
</div>
import draggable from 'vuedraggable'
end(evt){
  const formRowId = evt.from.id  //原行id
  const toRowId = evt.to.id  //目标行id
  const newIndex = evt.newIndex  //新index
  const oldIndex = evt.oldIndex  //原index
 },

oprions

group: { 
 name: 'draggableList',//将一个元素从一个列表拖动到另一个列表,必须有相同的name
 pull: 'clone', // true|false|'clone'|function|['list1','list2']; 默认为true,clone为复制元素
 put:true, //true| false| array|['list1','list2'] ; 是否可以从其他列表添加元素,或者指定一个数组,可以从此添加元素,默认为true,
 revertClone:true, // 将一个元素移动到另一个列表之后,将克隆的元素还原到初始位置
},
 sort: false, //允许在列表中排序
 delay: 0, //何时开始排序
 delayOnTouchOnly: 0, //使用触摸时的延迟ms
 touchStartThreshold: 0,//取消延迟拖动事件之前,点应该移动多少像素
 disabled: false, // 是否禁用排序
 store: null //
 animation: 150, //排序时的动画ms
 easing: "cubic-bezier(1, 0, 0, 1)", // Easing 动画,默认为空,[easing 动画地址](https://easings.net/)
 handle: ".my-handle",  // 拖动手柄选择器,css选择器
 filter: ".ignore-elements",  // 不允许拖动的选择器,字符串或者函数 css选择器
 preventOnFilter: true, // 在调用event.preventDefault()触发filter`
 draggable: ".item",  //指定元素中哪些项可以拖动,css选择器
 dataIdAttr: 'data-id',

ghostClass: "sortable-ghost",  // 占位符类名,添加样式
chosenClass: "sortable-chosen",  // 所选项目的类名,添加样式
dragClass: "sortable-drag",  // 拖动项目类名,添加样式

swapThreshold: 1, // 交换区域占目标的百分比就可以交换,0-1之间浮动,
invertSwap: false, // 当为true则反向交换区域
invertedSwapThreshold: 1, //反向交换的阈值,默认为swapThreshold的值
direction: 'horizontal', // 可排序的方向,'vertical', 'horizontal'
forceFallback: false,  // 忽略HTML5 DnD行为并强制回退,为true则使用H5浏览器的回退
fallbackClass: "sortable-fallback",  // 使用forceFallback时克隆的DOM元素的类名
fallbackOnBody: false,  // 将克隆的DOM元素追加到文档正文中
fallbackTolerance: 0, // 以像素为单位指定鼠标在被视为拖动之前应移动多远。

dragoverBubble: false, // 为true时dragover冒泡到父排序,适用于回退和本地dragover事件,默认为false,Sortable只会在元素插入父Sortable或可以插入父Sortable后停止冒泡事件。1.8版本后可以设置为false,1.8之前设置为true生效
removeCloneOnHide: true, // 为false时,将克隆的元素隐藏,默认为true,则该隐藏克隆元素时从dom删除此元素
emptyInsertThreshold: 5, // 拖动鼠标时,与空可排序表的距离(px),0为禁用


setData: function (dataTransfer, dragEl) {
   dataTransfer.setData('Text', dragEl.textContent); // `dataTransfer` object of HTML5 DragEvent
},

//已选择元素
onChoose: function (evt) {
   evt.oldIndex;  // 父级元素中的索引
},

// 元素未选择
onUnchoose: function(/**Event*/evt) {
    // same properties as onEnd
},

// 元素拖动开始
onStart: function (evt) {
   evt.oldIndex;  // element index within parent
},

// 元素拖动结束
onEnd: function (/**Event*/evt) {
   var itemEl = evt.item;  // 元素
   evt.to;    // 目标列表
   evt.from;  //原列表
   evt.oldIndex;  // 旧父级中的旧索引
   evt.newIndex;  // 新父级中的新索引
   evt.oldDraggableIndex; //旧父级中可拖动元素的旧索引
   evt.newDraggableIndex; // 新父级中可拖动元素的新索引
   evt.clone // 克隆
   evt.pullMode;  // 当项在另一个可排序表中时:如果是克隆,则为“克隆”;如果是移动,则为“真”

// 元素从另一个列表中拖放到列表中
onAdd: function (evt) {
   // same properties as onEnd
},

// 更改了列表内的排序
onUpdate: function (evt) {
   // same properties as onEnd
},

// 添加更新删除时都会调用
onSort: function (evt) {
   // same properties as onEnd
},

// 元素从一个列表移动到另一个列表
onRemove: function (evt) {
   // same properties as onEnd
},

// 尝试拖动筛选的元素
onFilter: function (evt) {
   var itemEl = evt.item;  // HTMLElement接收“mousedown”tapstart事件
},

// 在列表中或列表之间移动项目时发生的事件
onMove: function (evt, originalEvent) {
   evt.dragged; // dragged HTMLElement
   evt.draggedRect; //dom矩形(left,top,right,bottom)
   evt.related; // HTMLElement on which have guided
   evt.relatedRect; // DOMRect
   evt.willInsertAfter; // 如果为true则默认在元素之后插入
   originalEvent.clientY; //鼠标位置
   // return false; — for cancel 取消
   // return -1; — insert before target 在之前插入
   // return 1; — insert after target在之后插入
},

// 克隆时调用
onClone: function (evt) {
   var origEl = evt.item;
   var cloneEl = evt.clone;
},

// 当拖动元素更改位置时调用
onChange: function(evt) {
   evt.newIndex // 获取拖动元素的当前索引与onEnd属性相同
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,826评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,968评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,234评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,562评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,611评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,482评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,271评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,166评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,608评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,814评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,926评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,644评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,249评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,866评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,991评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,063评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,871评论 2 354