当前位置:首页 > VUE

vue如何实现拖拽

2026-02-18 04:55:00VUE

Vue 实现拖拽的方法

在 Vue 中实现拖拽功能可以通过多种方式,以下是几种常见的实现方法:

使用 HTML5 原生拖拽 API

HTML5 提供了原生的拖拽 API,可以通过 draggable 属性和相关事件实现拖拽功能。

<template>
  <div>
    <div 
      draggable="true" 
      @dragstart="handleDragStart"
      @dragend="handleDragEnd"
    >
      可拖拽元素
    </div>
    <div 
      @dragover.prevent
      @drop="handleDrop"
    >
      放置区域
    </div>
  </div>
</template>

<script>
export default {
  methods: {
    handleDragStart(event) {
      event.dataTransfer.setData('text/plain', event.target.id);
    },
    handleDrop(event) {
      const data = event.dataTransfer.getData('text/plain');
      const draggedElement = document.getElementById(data);
      event.target.appendChild(draggedElement);
    },
    handleDragEnd() {
      console.log('拖拽结束');
    }
  }
};
</script>

使用第三方库 vue-draggable

vue-draggable 是一个基于 Sortable.js 的 Vue 拖拽库,适合实现列表拖拽排序等功能。

安装依赖:

npm install vuedraggable

使用示例:

<template>
  <draggable v-model="list" @end="onDragEnd">
    <div v-for="item in list" :key="item.id">
      {{ item.name }}
    </div>
  </draggable>
</template>

<script>
import draggable from 'vuedraggable';

export default {
  components: {
    draggable
  },
  data() {
    return {
      list: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' }
      ]
    };
  },
  methods: {
    onDragEnd() {
      console.log('拖拽完成');
    }
  }
};
</script>

自定义拖拽实现

如果需要更灵活的拖拽逻辑,可以通过监听鼠标事件实现自定义拖拽。

<template>
  <div>
    <div 
      ref="draggableElement"
      @mousedown="startDrag"
      :style="elementStyle"
    >
      自定义拖拽元素
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      isDragging: false,
      startX: 0,
      startY: 0,
      offsetX: 0,
      offsetY: 0,
      elementStyle: {
        position: 'absolute',
        left: '0px',
        top: '0px'
      }
    };
  },
  methods: {
    startDrag(event) {
      this.isDragging = true;
      this.startX = event.clientX;
      this.startY = event.clientY;
      document.addEventListener('mousemove', this.onDrag);
      document.addEventListener('mouseup', this.stopDrag);
    },
    onDrag(event) {
      if (this.isDragging) {
        this.offsetX = event.clientX - this.startX;
        this.offsetY = event.clientY - this.startY;
        this.elementStyle.left = `${this.offsetX}px`;
        this.elementStyle.top = `${this.offsetY}px`;
      }
    },
    stopDrag() {
      this.isDragging = false;
      document.removeEventListener('mousemove', this.onDrag);
      document.removeEventListener('mouseup', this.stopDrag);
    }
  }
};
</script>

使用 Vue 指令实现拖拽

通过自定义指令可以封装拖拽逻辑,方便复用。

vue如何实现拖拽

<template>
  <div v-draggable>通过指令实现的拖拽元素</div>
</template>

<script>
export default {
  directives: {
    draggable: {
      inserted(el) {
        el.style.position = 'absolute';
        el.style.cursor = 'move';

        let startX = 0;
        let startY = 0;

        el.addEventListener('mousedown', (e) => {
          startX = e.clientX - el.offsetLeft;
          startY = e.clientY - el.offsetTop;

          document.addEventListener('mousemove', move);
          document.addEventListener('mouseup', up);
        });

        function move(e) {
          el.style.left = `${e.clientX - startX}px`;
          el.style.top = `${e.clientY - startY}px`;
        }

        function up() {
          document.removeEventListener('mousemove', move);
          document.removeEventListener('mouseup', up);
        }
      }
    }
  }
};
</script>

注意事项

  • 使用原生拖拽 API 时,需要阻止 dragover 事件的默认行为以允许放置。
  • 第三方库如 vue-draggable 提供了更丰富的功能,适合复杂场景。
  • 自定义拖拽实现灵活度高,但需要处理更多细节如边界检查、碰撞检测等。
  • 移动端拖拽实现可能需要额外处理触摸事件(touchstarttouchmovetouchend)。

分享给朋友:

相关文章

vue如何实现id

vue如何实现id

Vue 中实现 ID 的方法 在 Vue 中,可以通过多种方式为元素或组件分配唯一的 ID。以下是几种常见的方法: 使用 v-bind 绑定 ID 通过 v-bind 动态绑定 ID,可以在模板中直…

react如何实现分页

react如何实现分页

实现分页的基本思路 在React中实现分页通常需要以下几个核心步骤:管理当前页码状态、计算分页数据、渲染分页控件。以下是一个典型的分页实现方法。 管理分页状态 使用React的useState钩子来…

js 实现拖拽

js 实现拖拽

实现拖拽的基本步骤 在JavaScript中实现拖拽功能需要监听几个关键事件:mousedown、mousemove和mouseup。以下是实现的基本逻辑。 监听目标元素的mousedown事件,记…

vue如何实现404

vue如何实现404

实现 Vue 404 页面的方法 在 Vue 中实现 404 页面通常需要结合路由配置和动态路由匹配。以下是几种常见方法: 使用通配符路由匹配 在 Vue Router 配置中,可以通过 * 通配符…

vue实现面板拖拽

vue实现面板拖拽

Vue 实现面板拖拽的方法 使用 HTML5 原生拖拽 API HTML5 提供了原生的拖拽 API,可以通过 draggable 属性和相关事件实现拖拽功能。 在 Vue 模板中为元素添加 dra…

vue如何实现ifream

vue如何实现ifream

Vue 中实现 iframe 的方法 在 Vue 中可以通过多种方式实现 iframe 的嵌入和控制。以下是几种常见的方法: 使用 HTML 原生 iframe 标签 在 Vue 模板中直接使用…