欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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;  
  /* 過(guò)渡效果(如果需要) */  
  transition: transform 0.3s ease;  
}  
</style>

vue3 vue.draggable.next 拖拽插件

簡(jiǎn)單介紹

  • vue.draggable.next 是一款vue3的拖拽插件,是vue.draggable升級(jí)版本,同樣是基于Sortable.js實(shí)現(xiàn)的,你可以用它來(lái)拖拽列表、菜單、工作臺(tái)、選項(xiàng)卡等常見(jiàn)的工作場(chǎng)景。
  • 官網(wǎng)

安裝

npm i -S vuedraggable@next

導(dǎo)入組件

import draggable from 'vuedraggable'

屬性說(shuō)明

屬性名稱說(shuō)明
group如果一個(gè)頁(yè)面有多個(gè)拖拽區(qū)域,通過(guò)設(shè)置group名稱可以實(shí)現(xiàn)多個(gè)區(qū)域之間相互拖拽或者 { name: “…”, pull: [true, false, ‘clone’, array , function], put: [true, false, array , function] }
sort是否開(kāi)啟排序,如果設(shè)置為false,它所在組無(wú)法排序
delay鼠標(biāo)按下多少秒之后可以拖拽元素
touchStartThreshold鼠標(biāo)按下移動(dòng)多少px才能拖動(dòng)元素
disabled:disabled= “true”,是否啟用拖拽組件
animation拖動(dòng)時(shí)的動(dòng)畫(huà)效果,如設(shè)置animation=1000表示1秒過(guò)渡動(dòng)畫(huà)效果
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)速度

簡(jiǎn)單例子(只能在一組里拖拽切換排序)

<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',
   }
])

// 開(kāi)始拖拽
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)文章

最新評(píng)論