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-02vue項(xiàng)目使用node連接數(shù)據(jù)庫的方法(前后端分離)
這篇文章主要介紹了vue項(xiàng)目使用node連接數(shù)據(jù)庫(前后端分離),本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12vue3關(guān)于RouterView插槽和過渡動(dòng)效
這篇文章主要介紹了vue3關(guān)于RouterView插槽和過渡動(dòng)效,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06Vue3.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-09vue實(shí)現(xiàn)登錄時(shí)的圖片驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)登錄時(shí)的圖片驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04