Vue利用draggable實現(xiàn)多選拖拽效果
前言
最近產(chǎn)品提出一個排序需求,希望能進行拖拽排序,我一想,vue2插件這么多,sortable.js、draggable分分鐘實現(xiàn)了,但是還有一個需求希望能夠?qū)崿F(xiàn)多選拖拽,這個就有點麻煩,查詢了許多資料,暫時沒有發(fā)現(xiàn)能夠多選的拖拽組件,如果自己寫一個,既耗費時間,實現(xiàn)效果上必然沒有draggable這種成熟輪子效果好,于是決定基于draggable做改進。
實現(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">確認</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左右側(cè)聯(lián)動滾動的實現(xiàn)代碼
這篇文章主要介紹了vue左右側(cè)聯(lián)動滾動的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06
vue-cli整合vuex的時候,修改actions和mutations,實現(xiàn)熱部署的方法
今天小編就為大家分享一篇vue-cli整合vuex的時候,修改actions和mutations,實現(xiàn)熱部署的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09
Vite結(jié)合Vue刪除指定環(huán)境的console.log問題
這篇文章主要介紹了Vite結(jié)合Vue刪除指定環(huán)境的console.log問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03

