当前位置:首页 > VUE

vue组件的拖拽实现

2026-01-22 21:51:51VUE

使用 HTML5 原生拖拽 API

HTML5 提供了原生的拖拽 API,包括 draggabledragstartdragenddragenterdragoverdrop 等事件。在 Vue 中可以通过事件绑定实现基础拖拽功能。

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

<script>
export default {
  methods: {
    handleDragStart(e) {
      e.dataTransfer.setData('text/plain', '拖拽数据');
    },
    handleDrop(e) {
      const data = e.dataTransfer.getData('text/plain');
      console.log('接收到的数据:', data);
    }
  }
}
</script>

使用第三方库 vue-draggable

vue-draggable 是基于 Sortable.js 的 Vue 拖拽组件库,适用于列表排序、跨列表拖拽等复杂场景。

安装依赖:

npm install vuedraggable

基础用法:

vue组件的拖拽实现

<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' }
      ]
    };
  },
  methods: {
    onDragEnd() {
      console.log('排序后的列表:', this.list);
    }
  }
}
</script>

实现自定义拖拽指令

通过 Vue 自定义指令可以封装更灵活的拖拽逻辑,适合需要高度定制的场景。

<template>
  <div v-draggable @drag-start="logStart" @drag-end="logEnd">
    自定义指令拖拽元素
  </div>
</template>

<script>
export default {
  directives: {
    draggable: {
      inserted(el, binding) {
        el.setAttribute('draggable', true);
        el.addEventListener('dragstart', (e) => {
          binding.value && binding.value.onDragStart(e);
        });
        el.addEventListener('dragend', (e) => {
          binding.value && binding.value.onDragEnd(e);
        });
      }
    }
  },
  methods: {
    logStart(e) {
      console.log('开始拖拽', e);
    },
    logEnd(e) {
      console.log('结束拖拽', e);
    }
  }
}
</script>

跨组件拖拽通信

通过 Vuex 或事件总线实现跨组件拖拽数据传递,适用于复杂应用架构。

vue组件的拖拽实现

// store.js
import Vue from 'vue';
import Vuex from 'vuex';

Vue.use(Vuex);

export default new Vuex.Store({
  state: {
    draggedItem: null
  },
  mutations: {
    setDraggedItem(state, item) {
      state.draggedItem = item;
    }
  }
});

拖拽组件:

<template>
  <div 
    draggable 
    @dragstart="dragStart"
  >
    拖拽源
  </div>
</template>

<script>
export default {
  methods: {
    dragStart() {
      this.$store.commit('setDraggedItem', { id: 123 });
    }
  }
}
</script>

放置组件:

<template>
  <div @drop="handleDrop">
    放置目标
  </div>
</template>

<script>
export default {
  methods: {
    handleDrop() {
      const item = this.$store.state.draggedItem;
      console.log('接收到拖拽数据:', item);
    }
  }
}
</script>

移动端拖拽适配

移动端需要通过 touchstarttouchmovetouchend 事件模拟拖拽行为。

<template>
  <div 
    @touchstart="touchStart"
    @touchmove="touchMove"
    @touchend="touchEnd"
    :style="dragStyle"
  >
    移动端拖拽元素
  </div>
</template>

<script>
export default {
  data() {
    return {
      startX: 0,
      startY: 0,
      offsetX: 0,
      offsetY: 0
    };
  },
  computed: {
    dragStyle() {
      return {
        transform: `translate(${this.offsetX}px, ${this.offsetY}px)`
      };
    }
  },
  methods: {
    touchStart(e) {
      this.startX = e.touches[0].clientX;
      this.startY = e.touches[0].clientY;
    },
    touchMove(e) {
      this.offsetX = e.touches[0].clientX - this.startX;
      this.offsetY = e.touches[0].clientY - this.startY;
    },
    touchEnd() {
      // 拖拽结束处理
    }
  }
}
</script>

标签: 组件拖拽
分享给朋友:

相关文章

vue拖拽实现方式

vue拖拽实现方式

Vue拖拽实现方式 使用HTML5原生拖拽API HTML5提供了原生的拖拽API,可以通过draggable属性、dragstart、dragend、dragover和drop等事件实现基础拖拽功能…

vue实现组件

vue实现组件

Vue 实现组件的方法 Vue 中实现组件可以通过多种方式,包括全局注册、局部注册、单文件组件(SFC)等。以下是常见的实现方法。 全局注册组件 全局注册的组件可以在任何 Vue 实例或组件中使用。…

vue VUE实现日历组件功能

vue VUE实现日历组件功能

Vue 日历组件实现方法 基础日历结构 使用Vue的模板语法构建日历的HTML结构,通常包含头部(年月显示、切换按钮)和日历表格(星期标题和日期格子)。 <template> <…

vue实现组件跟随

vue实现组件跟随

Vue 实现组件跟随效果 实现组件跟随效果通常需要监听鼠标或触摸事件,动态更新组件位置。以下是几种常见实现方式: 使用鼠标事件绑定 <template> <div class=…

vue实现组件通信

vue实现组件通信

Vue 组件通信方法 Vue 提供了多种方式实现组件间的通信,适用于不同场景。以下是常见的方法: Props 和 Events 父组件通过 props 向子组件传递数据,子组件通过 $emit 触…

vue实现秒表组件

vue实现秒表组件

实现秒表组件的基本思路 使用Vue实现秒表组件需要管理时间状态、控制计时器的启动/暂停/重置功能,并通过计算属性动态显示格式化时间。核心逻辑包括利用setInterval更新计时数据,并通过生命周期钩…