拖动组件 vue-draggable-next 跨组件和clone问题

跨组件交互问题

问题描述:

当A,B组件 把 VueDraggableNext 都封装到其内部的时候,让A,B组件可以交互,比如把A中的数据元素拖动到B组件中,但是如果按照 每个组件都分别引用 VueDraggableNext 那么 A,B 组件之间分辨是两个实例,他们之间变不能交互。

解决方案:

VueDraggableNext 组件作为一个全局引用,A,B组件共同应用这个组件的,那么就是一个组件实例。

在vue3 中

ts 复制代码
//main.ts

import { VueDraggableNext } from 'vue-draggable-next'

const app = createApp(App)
app.provide('VueDraggableNext', VueDraggableNext)
ts 复制代码
// A组件
const VueDraggableNext = inject('VueDraggableNext')
ts 复制代码
// B组件
const VueDraggableNext = inject('VueDraggableNext')

这样就可以两个组件之间进行交互。

clone模式问题

问题描述

list 中的数据是个多层嵌套的对象,每次把list中的对象拖动新的组件数组中,并没有clone对象,而是引用原对象,不然拖拽第二个组件将会和第一个组件一模一样,改变第一个组件第二个、第三个也会跟着变动。解决方案是使用clone属性函数中拦截clone数据,让其创建新对象。

TS 复制代码
<template>
  <VueDraggableNext  
    :group="{ name:'ComponentList', pull:'clone', put:true }"
    :list="list"
    :force-fallback="true"
    :fallback-class="true"
    :fallback-on-body="false"
    item-key="id"
    @clone='cloneA' // 这里获取的是个原生对象相关的
    // 这里是获取的list中的某一项,拦截处理数据后会被拖动到另一个List
     :clone="(el:any) => { 
      const  clone = deepClone(el)
      return  clone
     }"
     :animation="500"
     >
     <div v-for="(item,index) in list" :key="index"></div>
   </VueDraggableNext>
</template>
相关推荐
源码宝3 分钟前
企业项目级医院随访系统源码,患者随访管理系统,技术框架:Java+Spring boot,Vue,Ant-Design+MySQL5
java·vue.js·spring·程序·医院管理系统·随访·随访系统源码
香香爱编程1 小时前
electron对于图片/视频无法加载的问题
前端·javascript·vue.js·chrome·vscode·electron·npm
蒲公英源码3 小时前
基于PHP+Vue+小程序快递比价寄件系统
vue.js·小程序·php
许___4 小时前
el-table多选模式下跨分页保留当前页选项
javascript·vue.js
程序定小飞5 小时前
基于springboot的学院班级回忆录的设计与实现
java·vue.js·spring boot·后端·spring
攀小黑6 小时前
基于若依-内容管理动态修改,通过路由字典配置动态管理
java·vue.js·spring boot·前端框架·ruoyi
Rysxt_6 小时前
Vuex 教程 从入门到实践
前端·javascript·vue.js
一 乐9 小时前
高校教务|教务管理|基于springboot+vue的高校教务管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·教务管理
zhousenshan9 小时前
ES6 import语法
vue.js
码界筑梦坊9 小时前
243-基于Django与VUE的笔记本电脑数据可视化分析系统
vue.js·python·信息可视化·数据分析·django·毕业设计·echarts