vue3 vue-draggable-next如何實(shí)現(xiàn)拖拽穿梭框效果
更新時(shí)間:2024年06月07日 09:10:23 作者:游九塵
這篇文章主要介紹了vue3 vue-draggable-next如何實(shí)現(xiàn)拖拽穿梭框效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
vue3 vue-draggable-next 拖拽穿梭框效果
<template>
<div>
<h2>列表 1</h2>
<draggable v-model="list1" group="items" tag="transition-group" @end="onDragEnd">
<div v-for="(item, index) in list1" :key="item.id" class="list-item">
{{ item.name }}
</div>
</draggable>
<h2>列表 2</h2>
<draggable v-model="list2" group="items" tag="transition-group" @end="onDragEnd">
<div v-for="(item, index) in list2" :key="item.id" class="list-item">
{{ item.name }}
</div>
</draggable>
</div>
</template> <script>
import draggable from 'vue-draggable-next';
export default {
components: {
draggable
},
data() {
return {
list1: [
{ id: 1, name: 'Item 1' },
{ id: 2, name: 'Item 2' }
// ...
],
list2: [
{ id: 3, name: 'Item 3' },
{ id: 4, name: 'Item 4' }
// ...
]
};
},
methods: {
onDragEnd(evt) {
// 這里可以添加拖動(dòng)結(jié)束后的邏輯,但通常不需要,因?yàn)閿?shù)據(jù)會(huì)自動(dòng)更新
console.log('Dragging ended:', evt);
}
}
};
</script> <style scoped>
.list-item {
/* 添加一些樣式以便區(qū)分 */
margin: 10px 0;
padding: 10px;
border: 1px solid #ddd;
border-radius: 5px;
/* 過渡效果(如果需要) */
transition: transform 0.3s ease;
}
</style>vue3 vue.draggable.next 拖拽插件
簡單介紹
- vue.draggable.next 是一款vue3的拖拽插件,是vue.draggable升級(jí)版本,同樣是基于Sortable.js實(shí)現(xiàn)的,你可以用它來拖拽列表、菜單、工作臺(tái)、選項(xiàng)卡等常見的工作場景。
- 官網(wǎng)
安裝
npm i -S vuedraggable@next
導(dǎo)入組件
import draggable from 'vuedraggable'
屬性說明
| 屬性名稱 | 說明 |
|---|---|
| group | 如果一個(gè)頁面有多個(gè)拖拽區(qū)域,通過設(shè)置group名稱可以實(shí)現(xiàn)多個(gè)區(qū)域之間相互拖拽或者 { name: “…”, pull: [true, false, ‘clone’, array , function], put: [true, false, array , function] } |
| sort | 是否開啟排序,如果設(shè)置為false,它所在組無法排序 |
| delay | 鼠標(biāo)按下多少秒之后可以拖拽元素 |
| touchStartThreshold | 鼠標(biāo)按下移動(dòng)多少px才能拖動(dòng)元素 |
| disabled | :disabled= “true”,是否啟用拖拽組件 |
| animation | 拖動(dòng)時(shí)的動(dòng)畫效果,如設(shè)置animation=1000表示1秒過渡動(dòng)畫效果 |
| handle | :handle=“.mover” 只有當(dāng)鼠標(biāo)在class為mover類的元素上才能觸發(fā)拖到事件 |
| filter | :filter=“.unmover” 設(shè)置了unmover樣式的元素不允許拖動(dòng) |
| draggable | :draggable=“.item” 樣式類為item的元素才能被拖動(dòng) |
| ghost-class | :ghost-class=“ghostClass” 設(shè)置拖動(dòng)元素的占位符類名,你的自定義樣式可能需要加!important才能生效,并把forceFallback屬性設(shè)置成true |
| chosen-class | :ghost-class=“hostClass” 被選中目標(biāo)的樣式,你的自定義樣式可能需要加!important才能生效,并把forceFallback屬性設(shè)置成true |
| drag-class | :drag-class="dragClass"拖動(dòng)元素的樣式,你的自定義樣式可能需要加!important才能生效,并把forceFallback屬性設(shè)置成true |
| force-fallback | 默認(rèn)false,忽略HTML5的拖拽行為,因?yàn)閔5里有個(gè)屬性也是可以拖動(dòng),你要自定義ghostClass chosenClass dragClass樣式時(shí),建議forceFallback設(shè)置為true |
| fallback-class | 默認(rèn)false,克隆選中元素的樣式到跟隨鼠標(biāo)的樣式 |
| fallback-on-body | 默認(rèn)false,克隆的元素添加到文檔的body中 |
| fallback-tolerance | 按下鼠標(biāo)移動(dòng)多少個(gè)像素才能拖動(dòng)元素,:fallback-tolerance=“8” |
| scroll | 默認(rèn)true,有滾動(dòng)區(qū)域是否允許拖拽 |
| scroll-fn | 滾動(dòng)回調(diào)函數(shù) |
| scroll-fensitivity | 距離滾動(dòng)區(qū)域多遠(yuǎn)時(shí),滾動(dòng)滾動(dòng)條 |
| scroll-speed | 滾動(dòng)速度 |
簡單例子(只能在一組里拖拽切換排序)
<template>
<div class="marc-content">
<table class="table">
<draggable sort="true" :list="MarcList"
:force-fallback="true" @start="startHandle" @end="endHandle">
<template #item="{ element }">
<tr>
<th>{{ element.Marc_title }}</th>
<td><input type="text" v-model="element.Marc_number"></td>
<td><input type="text" v-model="element.Marc_count"></td>
<td><input type="text" v-model="element.Marc_content"></td>
</tr>
</template>
</draggable>
</table>
</div>
</template><script setup lang='ts'>
import { ref, reactive } from 'vue'
import draggable from "vuedraggable";
// 定義 Marc 數(shù)據(jù)列表
const MarcList = reactive([
{
Marc_title: '字段名稱1',
Marc_number: '001',
Marc_count: '1 1',
Marc_content: '字段內(nèi)容1',
},
{
Marc_title: '字段名稱2',
Marc_number: '002',
Marc_count: '1 2',
Marc_content: '字段內(nèi)容2',
},
{
Marc_title: '字段名稱3',
Marc_number: '003',
Marc_count: '0 3',
Marc_content: '字段內(nèi)容3',
},
{
Marc_title: '字段名稱4',
Marc_number: '004',
Marc_count: '1 4',
Marc_content: '字段內(nèi)容4',
},
{
Marc_title: '字段名稱5',
Marc_number: '005',
Marc_count: '0 5',
Marc_content: '字段內(nèi)容5',
}
])
// 開始拖拽
const startHandle = (e: any) => {
console.log(e);
}
// 結(jié)束拖拽
const endHandle = (e: any) => {
console.log(e);
}
</script><style scoped lang="less">
.marc-content {
margin: 15px 0;
.table,
.table tr td,
th {
height: 35px;
min-height: 35px;
border-collapse: collapse;
border: 1px solid #fff;
padding: 0 10px;
font-size: 16px;
color: #333;
box-sizing: border-box;
}
.table {
tr {
th {
background: #A9C8C6;
border-right: 2px solid rgb(127, 164, 156);
cursor: pointer;
}
}
}
.table {
tr {
&:hover {
background: rgba(127, 164, 156, 0.3);
th {
background: inherit;
border-right: 2px solid #ff0000;
}
}
}
}
}
</style>總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue+ElementUI實(shí)現(xiàn)動(dòng)態(tài)更換任意主題色(動(dòng)態(tài)換膚)的全過程
眾所周知Element-UI有換膚功能,下面這篇文章主要給大家介紹了關(guān)于Vue+ElementUI實(shí)現(xiàn)動(dòng)態(tài)更換任意主題色(動(dòng)態(tài)換膚)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
vue項(xiàng)目使用node連接數(shù)據(jù)庫的方法(前后端分離)
這篇文章主要介紹了vue項(xiàng)目使用node連接數(shù)據(jù)庫(前后端分離),本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12
vue3關(guān)于RouterView插槽和過渡動(dòng)效
這篇文章主要介紹了vue3關(guān)于RouterView插槽和過渡動(dòng)效,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
Vue3.5中新增的baseWatch函數(shù)用法詳解
在Vue 3.5.0-beta.3版本中新增了一個(gè)base watch函數(shù),這個(gè)函數(shù)用法和我們熟知的watch API一模一樣,下面就跟隨小編一起來了解一下它的具體使用吧2024-11-11
淺談vue引用靜態(tài)資源需要注意的事項(xiàng)
今天小編就為大家分享一篇淺談vue引用靜態(tài)資源需要注意的事項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vue實(shí)現(xiàn)登錄時(shí)的圖片驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)登錄時(shí)的圖片驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04

