vue实现div拖拽互换位置

news/2024/7/10 1:29:02 标签: vue

template模板

<transition-group tag="div" class="container">
  <div class="item" v-for="(item,index) in items" :key="item.key" :style="{background:item.color,width:'80px',height:'80px'}"
    draggable="true"
  @dragstart="handleDragStart($event, item)"
    @dragover.prevent="handleDragOver($event, item)"
    @dragenter="handleDragEnter($event, item)"
    @dragend="handleDragEnd($event, item)" >
  </div>
</transition-group>

script:

<script>
export default {
 name: 'Toolbar',
 data () {
  return {
   items: [
    { key: 1, color: '#ffebcc'},
    { key: 2, color: '#ffb86c'},
    { key: 3, color: '#f01b2d'}
   ],
     
    dragging: null
  }
 },
 methods:{
  handleDragStart(e,item){
    this.dragging = item;
  },
  handleDragEnd(e,item){
    this.dragging = null
  },
  //首先把div变成可以放置的元素,即重写dragenter/dragover
  handleDragOver(e) {
    e.dataTransfer.dropEffect = 'move'// e.dataTransfer.dropEffect="move";//在dragenter中针对放置目标来设置!
  },
  handleDragEnter(e,item){
    e.dataTransfer.effectAllowed = "move"//为需要移动的元素设置dragstart事件
    if(item === this.dragging){
      return
    }
    const newItems = [...this.items]
    console.log(newItems)
    const src = newItems.indexOf(this.dragging)
    const dst = newItems.indexOf(item)
  
    newItems.splice(dst, 0, ...newItems.splice(src, 1))
  
    this.items = newItems
  }
 }
}
</script>
  
<style scoped>
  .container{
    width: 80px;
    height: 300px;
    position: absolute;
    left: 0;
    display:flex;
    flex-direction: column;
    padding: 0;
  }
  .item {
   margin-top: 10px;
   transition: all linear .3s
  }

最后

为了帮助大家让学习变得轻松、高效,给大家免费分享一大批资料,帮助大家在成为全栈工程师,乃至架构师的路上披荆斩棘。在这里给大家推荐一个前端全栈学习交流圈:866109386.欢迎大家进群交流讨论,学习交流,共同进步。

当真正开始学习的时候难免不知道从哪入手,导致效率低下影响继续学习的信心。

但最重要的是不知道哪些技术需要重点掌握,学习时频繁踩坑,最终浪费大量时间,所以有有效资源还是很有必要的。

最后祝福所有遇到瓶疾且不知道怎么办的前端程序员们,祝福大家在往后的工作与面试中一切顺利。


http://www.niftyadmin.cn/n/1300870.html

相关文章

__declspec(dllexport) 与 __declspec(dllimport)

__declspec(dllexport):导出符号,也就是定义需要导出函数的dll中给导出函数的函数声明前面加上导出符号,表示该方法可以导出给其他DLL或者exe使用; __declspec(dllimport)导入符号,也就是在使用该函数的DLL或者exe中需要在该函数的函数声明前面加上该符号,表示该函数方法…

浅谈“全栈工程师需要掌握哪些技能”

全栈工程师有很多种&#xff0c;以经典有Web开发体系中有&#xff1a; Java JavaScript/css/htmlNodejs JavaScript/css/html其他服务端语言 JavaScript/css/html 本次给大家推荐的就是用 Nodejs JavaScript/css/html成为全栈的学习路线。 第一阶段&#xff1a;web网页基…

dll 详解与调用

DLL(Dynamic Link Library)的概念,你可以简单的把DLL看成一种仓库,它提供给你一些可以直接拿来用的变量、函数或类。

JavaScript中发出HTTP请求最常用的方法

JavaScript具有很好的模块和方法来发送可用于从服务器端资源发送或接收数据的HTTP请求。在本文中&#xff0c;我们将介绍一些在JavaScript中发出HTTP请求的流行方法。 Ajax Ajax是发出异步HTTP请求的传统方式。可以使用HTTP POST方法发送数据&#xff0c;并使用HTTP GET方法接…

虚函数表详解

1. 指针长度 (1) 32位操作系统 指针长度为4字节, 64位操作系统指针长度为8字节 (2) new一个对象时, 只为类中成员变量分配空间, 对象之间共享成员函数 <

详解在Vue中使用TypeScript的一些思考(实践)

Vue.extend or vue-class-component 使用 TypeScript 写 Vue 组件时&#xff0c;有两种推荐形式&#xff1a; Vue.extend()&#xff1a;使用基础 Vue 构造器&#xff0c;创建一个“子类”。此种写法与 Vue 单文件组件标准形式最为接近&#xff0c;唯一不同仅是组件选项需要被…

COM浅析

COM是Component object model的缩写。中文名为组件对象模型。 传统的软件由单个的二进制文件组成。组件将单个二进制文件分割为多个独立的部分&#xff0c;每个部分都被称为一个组件。采用组件技术后&#xff0c;在需要对程序进行修改和改进时&#xff0c;只需替换某个组件模块…

axios携带cookie配置详解(axios+koa)

话不多说&#xff0c;一个字&#xff0c;干&#xff01; 前端配置如下&#xff1a; axios.defaults.withCredentials true; //配置为trueaxios.post(http://localhost:3000/tpzdz/vote/all, {openid: oJ0mVw4QrfS603gFa_uAFDADH2Uc,date: 2018-11-21 }).then(function (resp…