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: 拖拽结束时清理样式

相关推荐
1024小神2 分钟前
如何快速copy复制一个网站,或是将网站本地静态化访问
前端
掘金一周2 分钟前
DeepSeek删豆包冲上热搜,大模型世子之争演都不演了 | 掘金一周 8.28
前端·人工智能·后端
moyu847 分钟前
前端存储三剑客:Cookie、LocalStorage 与 SessionStorage 全方位解析
前端
不爱说话郭德纲10 分钟前
👩‍💼产品姐一句小优化,让我给上百个列表加上一个动态实时计算高度的方法😿😿
前端·vue.js·性能优化
现在没有牛仔了13 分钟前
小试牛刀,用electron+vue3做了一个文件归纳程序~
前端·electron
FogLetter15 分钟前
Prisma + Next.js 全栈开发初体验:像操作对象一样玩转数据库
前端·后端·next.js
知识分享小能手15 分钟前
React学习教程,从入门到精通, React教程:构建你的第一个 React 应用(1)
前端·javascript·vue.js·学习·react.js·ajax·前端框架
李剑一16 分钟前
别乱封装,你看出事儿了吧...
前端·vue.js
文心快码BaiduComate20 分钟前
新增Zulu-CLI、企业版对话支持自定义模型、一键设置自动执行、复用相同终端,8月新能力速览!
前端·后端·程序员
walking95723 分钟前
JavaScript 神技巧!从 “堆代码” 到 “写优雅代码”,前端人必看
前端·面试