vue拖动排序,vue使用 HTML5 的draggable拖放 API实现内容拖并排序,并更新数组数据

vue拖动排序,vue使用 HTML5 的draggable拖放 API实现内容拖并排序,并更新数组数据

vue使用 HTML5 的draggable拖放 API实现内容拖并排序,并更新数组数据

  • 实现效果
  • 实现代码
    • 1.模板部分
    • [2. 添加拖拽相关方法](#2. 添加拖拽相关方法)
    • [3. 在 data 中添加拖拽状态变量](#3. 在 data 中添加拖拽状态变量)
    • [4. 添加样式优化(可选)](#4. 添加样式优化(可选))
  • 功能说明:

实现效果

HTML5 draggable拖拽API实现内容拖动排序

实现代码

1.模板部分

将你的循环部分修改为支持拖拽:

vue

bash 复制代码
<template>
  <div v-for="(item, index) in imgs" 
       :key="index"
       :class="['text_pics_box_item']"
       draggable="true"
       @dragstart="dragStart($event, index)"
       @dragover.prevent
       @dragenter="dragEnter($event, index)"
       @drop="drop($event, index)"
       @dragend="dragEnd"
       @mouseover="hovervariableItem(index)" 
       @mouseleave="unhovervariableItem">
    <div class="text_pics_box_item_img">
      <img  :src="item">
    </div>

</template>

2. 添加拖拽相关方法

在 methods 中添加以下方法:

bash 复制代码
methods: {
  // 拖拽开始
  dragStart(event, index) {
    event.dataTransfer.effectAllowed = 'move';
    event.dataTransfer.setData('text/plain', index);
    this.draggingIndex = index;
    
    // 添加拖拽样式
    event.target.style.opacity = '0.5';
    event.target.style.transform = 'scale(0.95)';
  },
  
  // 拖拽进入
  dragEnter(event, index) {
    event.preventDefault();
    if (this.draggingIndex !== index) {
      // 可以添加视觉反馈,比如高亮目标位置
      const targetElement = event.target.closest('.text_pics_box_item');
      if (targetElement) {
        targetElement.style.boxShadow = '0 0 0 2px #3855d5';
      }
    }
  },
  
  // 拖拽放置
  drop(event, index) {
    event.preventDefault();
    const draggedIndex = parseInt(event.dataTransfer.getData('text/plain'));
    
    if (draggedIndex !== index) {
      // 重新排列数组
      this.reorderImages(draggedIndex, index);
    }
    
    // 清除视觉反馈
    const targetElement = event.target.closest('.text_pics_box_item');
    if (targetElement) {
      targetElement.style.boxShadow = '';
    }
  },
  
  // 拖拽结束
  dragEnd(event) {
    // 恢复元素样式
    event.target.style.opacity = '';
    event.target.style.transform = '';
    
    // 清除所有元素的视觉反馈
    const items = document.querySelectorAll('.text_pics_box_item');
    items.forEach(item => {
      item.style.boxShadow = '';
    });
    
    this.draggingIndex = null;
  },
  
  // 重新排列图片数组
  reorderImages(fromIndex, toIndex) {
    const images = [...this.form.imgs];
    const [movedItem] = images.splice(fromIndex, 1);
    images.splice(toIndex, 0, movedItem);
    
    // 更新数组
    this.form.imgs = images;
    
  },
}

3. 在 data 中添加拖拽状态变量

bash 复制代码
data() {
  return {
    draggingIndex: null,  // 当前正在拖拽的元素索引
  }
}

4. 添加样式优化(可选)

<style> 部分添加一些拖拽相关的样式:

bash 复制代码
.text_pics_box_item {
  transition: all 0.2s ease;
}

.text_pics_box_item.drag-over {
  border: 2px dashed #3855d5;
  background-color: rgba(56, 85, 213, 0.1);
}

功能说明:

draggable="true": 使元素可拖拽
@dragstart: 拖拽开始时记录被拖拽元素的索引
@dragover.prevent: 阻止默认行为,允许放置
@dragenter: 拖拽进入目标元素时的视觉反馈
@drop: 放置元素时重新排列数组
@dragend: 拖拽结束时清理样式

相关推荐
FIN66687 分钟前
射频技术领域的领航者,昂瑞微IPO即将上会审议
前端·人工智能·前端框架·信息与通信
U.2 SSD16 分钟前
ECharts漏斗图示例
前端·javascript·echarts
江城开朗的豌豆16 分钟前
我的小程序登录优化记:从短信验证到“一键获取”手机号
前端·javascript·微信小程序
excel20 分钟前
Vue Mixin 全解析:概念、使用与源码
前端·javascript·vue.js
IT_陈寒27 分钟前
Java性能优化:这5个Spring Boot隐藏技巧让你的应用提速40%
前端·人工智能·后端
勇往直前plus1 小时前
CentOS 7 环境下 RabbitMQ 的部署与 Web 管理界面基本使用指南
前端·docker·centos·rabbitmq
北海-cherish6 小时前
vue中的 watchEffect、watchAsyncEffect、watchPostEffect的区别
前端·javascript·vue.js
2501_915909067 小时前
HTML5 与 HTTPS,页面能力、必要性、常见问题与实战排查
前端·ios·小程序·https·uni-app·iphone·html5
white-persist8 小时前
Python实例方法与Python类的构造方法全解析
开发语言·前端·python·原型模式
新中地GIS开发老师9 小时前
Cesium 军事标绘入门:用 Cesium-Plot-JS 快速实现标绘功能
前端·javascript·arcgis·cesium·gis开发·地理信息科学