前言
vuedraggable
是一个基于Sortable.js
库的Vue.js
拖拽功能组件。
资料
npm 地址 下载量还是蛮高的
github 地址
star
数还是蛮多的
简单的安装与使用
-
安装
yarn add vuedraggable # or npm i -S vuedraggable
-
使用(源码出处 custom-clone)
<template> <div class="row"> <div class="col-3"> <h3>Draggable 1</h3> <draggable class="dragArea list-group" :list="list1" :group="{ name: 'people', pull: 'clone', put: false }" :clone="cloneDog" @change="log" > <div class="list-group-item" v-for="element in list1" :key="element.id"> {{ element.name }} </div> </draggable> </div> <div class="col-3"> <h3>Draggable 2</h3> <draggable class="dragArea list-group" :list="list2" group="people" @change="log" > <div class="list-group-item" v-for="element in list2" :key="element.id"> {{ element.name }} </div> </draggable> </div> <rawDisplayer class="col-3" :value="list1" title="List 1" /> <rawDisplayer class="col-3" :value="list2" title="List 2" /> </div> </template> <script> import draggable from "@/vuedraggable"; let idGlobal = 8; export default { name: "custom-clone", display: "Custom Clone", order: 3, components: { draggable }, data() { return { list1: [ { name: "dog 1", id: 1 }, { name: "dog 2", id: 2 }, { name: "dog 3", id: 3 }, { name: "dog 4", id: 4 } ], list2: [ { name: "cat 5", id: 5 }, { name: "cat 6", id: 6 }, { name: "cat 7", id: 7 } ] }; }, methods: { log: function(evt) { window.console.log(evt); }, cloneDog({ id }) { return { id: idGlobal++, name: `cat ${id}` }; } } }; </script> <style scoped></style>
项目使用中具体需要注意的细节
-
当使用两个拖拽组件,需要向目标组件拖拽时无效。
当使用两个拖拽组件,需要向目标组件拖拽时,需要注意:两个字段值,它们的值必须得是相同的。
这样的话,两个组件的拖拽功能才能生效,具体如下:
- 拖拽组件
- 目标组件
>![目标组件](https://upload-images.jianshu.io/upload_images/9064013-d7a22f75fe066050.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)