欧美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;  
  /* 過渡效果(如果需要) */  
  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中使用公共過濾器filter的方法

    在vue中使用公共過濾器filter的方法

    這篇文章主要介紹了在vue中使用公共過濾器filter的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-06-06
  • Vue+ElementUI實(shí)現(xiàn)動(dòng)態(tài)更換任意主題色(動(dòng)態(tài)換膚)的全過程

    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ù)庫的方法(前后端分離)

    這篇文章主要介紹了vue項(xiàng)目使用node連接數(shù)據(jù)庫(前后端分離),本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-12-12
  • 源碼分析Vue3響應(yīng)式核心之reactive

    源碼分析Vue3響應(yīng)式核心之reactive

    這篇文章主要為大家詳細(xì)介紹了Vue3響應(yīng)式核心之reactive的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Vue3有一定的幫助,需要的可以參考一下
    2023-04-04
  • vue+echart實(shí)現(xiàn)圓滑折線圖

    vue+echart實(shí)現(xiàn)圓滑折線圖

    這篇文章主要為大家詳細(xì)介紹了vue+echart實(shí)現(xiàn)圓滑折線圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue3關(guān)于RouterView插槽和過渡動(dòng)效

    vue3關(guān)于RouterView插槽和過渡動(dòng)效

    這篇文章主要介紹了vue3關(guān)于RouterView插槽和過渡動(dòng)效,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Vue3.5中新增的baseWatch函數(shù)用法詳解

    Vue3.5中新增的baseWatch函數(shù)用法詳解

    在Vue 3.5.0-beta.3版本中新增了一個(gè)base watch函數(shù),這個(gè)函數(shù)用法和我們熟知的watch API一模一樣,下面就跟隨小編一起來了解一下它的具體使用吧
    2024-11-11
  • vue如何向后臺(tái)傳遞日期

    vue如何向后臺(tái)傳遞日期

    這篇文章主要介紹了vue如何向后臺(tái)傳遞日期,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 淺談vue引用靜態(tài)資源需要注意的事項(xiàng)

    淺談vue引用靜態(tài)資源需要注意的事項(xiàng)

    今天小編就為大家分享一篇淺談vue引用靜態(tài)資源需要注意的事項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue實(shí)現(xiàn)登錄時(shí)的圖片驗(yàn)證碼

    vue實(shí)現(xiàn)登錄時(shí)的圖片驗(yàn)證碼

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)登錄時(shí)的圖片驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-04-04

最新評(píng)論