vue使用vuedraggable实现嵌套多层拖拽排序功能

Iris ·
更新时间:2024-11-13
· 1865 次阅读

本文实例为大家分享了vuedraggable实现嵌套多层拖拽排序功能的具体代码,供大家参考,具体内容如下

vue中实现嵌套多层拖拽功能。官网入口:

实现效果:(拖动左侧调整一级的顺序,拖动右侧调整二级的顺序)

实现步骤:

***这里使用了插件  vuedraggable

第一步:安装插件

cnpm install vuedraggable --save

第二步:在页面上引入插件并注册

import draggable from 'vuedraggable' components: {     draggable   },

第三步:页面上使用

<template>   <div class="wholeList">     <draggable       class="leftCon"       :list="tolList"     >       <div class="leftConLi" v-for="element in tolList" :key="element.id">         {{ element.name }}       </div>     </draggable>     <ul class="oneUl">       <li         class="oneLi"         v-for="(item,index) in tolList"         :key="index"       >         <!--拖拽内容部分-1-->         <draggable           v-if="index === 0"           class="dragArea list-group"           :list="item.children"           :clone="clone"           :group="{ name: 'people', pull: pullFunction }"           @start="start"         >           <div v-for="element in item.children" :key="element.id" class="list-group-item">             {{ element.name }}           </div>         </draggable>         <!--拖拽内容部分-其他-->         <draggable           v-else           class="dragArea list-group"           :list="item.children"           :clone="clone"           group="people"         >           <div v-for="element in item.children" :key="element.id" class="list-group-item">             {{ element.name }}           </div>         </draggable>       </li>     </ul>     <el-button @click="getNewList">点我看console里面的最新数据</el-button>   </div> </template> <script> import draggable from 'vuedraggable' export default {   components: {     draggable   },   data() {     return {       tolList: [         {           name: '第一天',           children: [             {               name: '11111', id: 1             }           ]         }, {           name: '第二天',           children: [             {               name: 'aaaaa', id: 11             }, {               name: 'bbbbbb', id: 12             }           ]         },         {           name: '第三天',           children: [             {               name: ',,,111,,', id: 21             }           ]         }       ],       controlOnStart: true     }   },   methods: {     clone({ name, id }) {       return { name, id: id }     },     pullFunction() {       return this.controlOnStart ? 'clone' : true     },     start({ originalEvent }) {       this.controlOnStart = originalEvent.ctrlKey     },     getNewList() {       let a = this.tolList       console.log(a)     }   } } </script> <style lang="scss" scoped>   .wholeList{     margin-top:200px;     width:500px;     display: flex;     flex-wrap: wrap;     .leftCon{       width: 100px;       .leftConLi{         background: #42B974;         line-height: 80px;         margin-bottom:10px;       }     }     .oneUl{       width: calc(100% - 100px);       .oneLi{         display: flex;         height: 80px;         margin-bottom:10px;         border:1px solid red;         .dragArea{           width: 100%;           min-height: 30px;         }       }     }   } </style>



VUE vuedraggable 排序 嵌套

需要 登录 后方可回复, 如果你还没有账号请 注册新账号