Vue利用draggable實現(xiàn)多選拖拽效果
前言
最近產(chǎn)品提出一個排序需求,希望能進(jìn)行拖拽排序,我一想,vue2插件這么多,sortable.js、draggable分分鐘實現(xiàn)了,但是還有一個需求希望能夠?qū)崿F(xiàn)多選拖拽,這個就有點麻煩,查詢了許多資料,暫時沒有發(fā)現(xiàn)能夠多選的拖拽組件,如果自己寫一個,既耗費時間,實現(xiàn)效果上必然沒有draggable這種成熟輪子效果好,于是決定基于draggable做改進(jìn)。
實現(xiàn)思路
我們知道draggable插件只要設(shè)置相同的group名字就能實現(xiàn)分組拖拽,如果我們渲染兩個同名分組,控制第二個分組的顯示與隱藏,魚目混珠,就能實現(xiàn)簡單的多選拖拽效果
1.通過group="task"設(shè)置兩個同名分組,同時利用draggable=".card"屬性,控制class名稱,禁止單選
<draggable group="task" v-model="dataList" @end="draggerEnd" class="" :class="show ? 'order-box-show' : 'order-box'" animation="300" draggable=".card"> <transition-group> <div v-for="(item, index) in dataList" :key="index" class="box" @click="handleSelect(index)" :class="item.select || show ? 'card' : ''">{{ item.name }} </div> </transition-group> </draggable> <div class="position" v-show="show"> <draggable group="task" v-model="dataList2" @end="draggerEnd" class="order-box" animation="300"> <transition-group> <div v-for="(item, index) in dataList2" :key="index" class="boxs"> <div> {{ item.name }} </div> </div> </transition-group> </draggable>
2.通過v-show="show"控制第二個分組的隱藏與展示,同時對數(shù)據(jù)做處理,并且在拖拽結(jié)束后,要在分組一中找到分組二拖拽過來的初始元素刪掉
const findIndex = this.dataList.findIndex((item => item.name === '選中元素展示區(qū)')) this.dataList.splice(findIndex, 1)
Demo全部代碼
<template> <div> <div> <draggable group="task" v-model="dataList" @end="draggerEnd" class="" :class="show ? 'order-box-show' : 'order-box'" animation="300" draggable=".card"> <transition-group> <div v-for="(item, index) in dataList" :key="index" class="box" @click="handleSelect(index)" :class="item.select || show ? 'card' : ''">{{ item.name }} </div> </transition-group> </draggable> <div class="position" v-show="show"> <draggable group="task" v-model="dataList2" @end="draggerEnd" class="order-box" animation="300"> <transition-group> <div v-for="(item, index) in dataList2" :key="index" class="boxs"> <div> {{ item.name }} </div> </div> </transition-group> </draggable> </div> </div> <el-button style="marginLeft:50px" @click="handleStart">確認(rèn)</el-button> </div> </template> <script> import draggable from 'vuedraggable' export default { components: { draggable }, data() { return { dataList: [ ], dataList2: [{ name: '選中元素展示區(qū)' }], show: false, selectArr: [], } }, mounted() { for (var i = 0; i < 60; i++) { this.dataList.push({ name: i, select: false }) } }, methods: { handleSelect(index) { const data = JSON.parse(JSON.stringify(this.dataList)) data[index].select = true this.selectArr.push({ ...data[index] }) this.dataList = JSON.parse(JSON.stringify(data)) }, handleStart(e) { if (!this.selectArr.length) { return } this.show = true this.selectArr.forEach((item, index) => { const Index = this.dataList.findIndex(it => item.name === it.name) this.dataList.splice(Index, 1) }) }, draggerEnd(e) { const newIndex = e.newIndex this.dataList.splice(newIndex, 0, ...this.selectArr) const findIndex = this.dataList.findIndex((item => item.name === '選中元素展示區(qū)')) this.dataList.splice(findIndex, 1) this.show = false }, } } </script> <style lang="scss" scoped> .order-box { padding: 20px 50px; display: flex; flex-wrap: wrap; >span { flex: 1; display: flex; flex-wrap: wrap; } .box { width: 100px; height: 50px; background: rgb(7, 174, 215); margin-right: 10px; margin-bottom: 10px; } .boxs { width: 100px; height: 50px; background: rgb(215, 177, 7); margin-right: 10px; margin-bottom: 10px; } .card { background: rgb(128, 68, 0) !important; } } .order-box-show { padding: 20px 50px; display: flex; flex-wrap: wrap; >span { flex: 1; display: flex; flex-wrap: wrap; } .box { width: 100px; height: 50px; background: rgb(7, 174, 215); margin-right: 10px; margin-bottom: 10px; } .boxs { width: 100px; height: 50px; background: rgb(215, 177, 7); margin-right: 10px; margin-bottom: 10px; } } .position { border: 1px solid red; position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); cursor: pointer; } </style>
Demo實現(xiàn)效果
到此這篇關(guān)于Vue利用draggable實現(xiàn)多選拖拽效果的文章就介紹到這了,更多相關(guān)Vue draggable多選拖拽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue?element-plus圖片預(yù)覽實現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于vue?element-plus圖片預(yù)覽實現(xiàn)的相關(guān)資料,最近的項目中有圖片預(yù)覽的場景,也是踩了一些坑,在這里總結(jié)一下,需要的朋友可以參考下2023-07-07Vue配置proxy代理接口報錯2007 bad domain的解決
本文主要介紹了Vue配置proxy代理接口報錯2007 bad domain的解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06vue3中使用props和emits并指定其類型與默認(rèn)值
props是Vue3中的一個重要概念,它允許我們將數(shù)據(jù)從父組件傳遞到子組件,下面這篇文章主要給大家介紹了關(guān)于vue3中使用props和emits并指定其類型與默認(rèn)值的相關(guān)資料,需要的朋友可以參考下2023-04-04vue.js前后端數(shù)據(jù)交互之提交數(shù)據(jù)操作詳解
這篇文章主要介紹了vue.js前后端數(shù)據(jù)交互之提交數(shù)據(jù)操作,結(jié)合實例形式較為詳細(xì)的分析了vue.js前后端數(shù)據(jù)交互相關(guān)的表單結(jié)構(gòu)、約束規(guī)則、數(shù)據(jù)提交等相關(guān)操作技巧與注意事項,需要的朋友可以參考下2018-04-04vue自定義組件如何通過v-model指令控制組件的隱藏、顯示
這篇文章主要介紹了vue自定義組件如何通過v-model指令控制組件的隱藏、顯示,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05