天天看點

Vue.Draggable拖拽效果

1.下載下傳包:npm install vuedraggable

配置:package.json

Vue.Draggable拖拽效果
"dependencies": {
    "vuedraggable": "^2.11.0"
  },      
Vue.Draggable拖拽效果

2.在你的元件中引進依賴:

import draggable from 'vuedraggable'      

3.注冊:draggable這個元件

components: {
  draggable
},      

4.使用html模闆中使用該元件

<draggable v-model="tags" :move="getdata" @update="datadragEnd">
        <transition-group>
            <div v-for="element in tags" :key="element.id">
                {{element.name}}
            </div>
        </transition-group>
</draggable>      
Vue.Draggable拖拽效果

5.有兩個常用的方法

一個是拖動中

一個是拖動結束

Vue.Draggable拖拽效果
methods: {
      getdata (evt) {
        console.log(evt.draggedContext.element.id)
      },
      datadragEnd (evt) {
        console.log('拖動前的索引 :' + evt.oldIndex)
        console.log('拖動後的索引 :' + evt.newIndex)
        console.log(this.tags)
      }
    }      

配置:package.json

Vue.Draggable拖拽效果
"dependencies": {
    "vuedraggable": "^2.11.0"
  },      
Vue.Draggable拖拽效果

2.在你的元件中引進依賴:

import draggable from 'vuedraggable'      

3.注冊:draggable這個元件

components: {
  draggable
},      

4.使用html模闆中使用該元件

Vue.Draggable拖拽效果
<draggable v-model="tags" :move="getdata" @update="datadragEnd">
        <transition-group>
            <div v-for="element in tags" :key="element.id">
                {{element.name}}
            </div>
        </transition-group>
</draggable>      
Vue.Draggable拖拽效果

5.有兩個常用的方法

一個是拖動中

一個是拖動結束

Vue.Draggable拖拽效果
methods: {
      getdata (evt) {
        console.log(evt.draggedContext.element.id)
      },
      datadragEnd (evt) {
        console.log('拖動前的索引 :' + evt.oldIndex)
        console.log('拖動後的索引 :' + evt.newIndex)
        console.log(this.tags)
      }
    }      
下一篇: enum枚舉