当前位置:首页 > VUE

vue实现drag

2026-02-10 00:57:26VUE

Vue 实现拖拽功能的方法

使用 HTML5 原生拖拽 API

HTML5 提供了原生的拖拽 API,可以通过 draggable 属性和相关事件实现拖拽功能。在 Vue 中可以直接使用这些 API。

<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);
    },
    handleDragEnd() {
      console.log('拖拽结束');
    }
  }
}
</script>

使用第三方库 Vue.Draggable

Vue.Draggable 是一个基于 Sortable.js 的 Vue 拖拽组件,适用于列表拖拽排序等场景。

vue实现drag

安装 Vue.Draggable:

npm install vuedraggable

使用示例:

vue实现drag

<template>
  <div>
    <draggable 
      v-model="list" 
      @end="onDragEnd"
    >
      <div v-for="item in list" :key="item.id">
        {{ item.name }}
      </div>
    </draggable>
  </div>
</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('拖拽后的列表:', this.list);
    }
  }
}
</script>

自定义拖拽指令

可以通过 Vue 的自定义指令功能实现更灵活的拖拽控制。

<template>
  <div>
    <div v-draggable @drag-start="onDragStart" @drag-end="onDragEnd">
      可拖拽元素
    </div>
    <div class="drop-zone" @drop="onDrop" @dragover.prevent>
      放置区域
    </div>
  </div>
</template>

<script>
export default {
  directives: {
    draggable: {
      bind(el, binding, vnode) {
        el.setAttribute('draggable', true);
        el.addEventListener('dragstart', (e) => {
          vnode.context.$emit('drag-start', e);
        });
        el.addEventListener('dragend', (e) => {
          vnode.context.$emit('drag-end', e);
        });
      }
    }
  },
  methods: {
    onDragStart(e) {
      console.log('开始拖拽');
    },
    onDragEnd(e) {
      console.log('结束拖拽');
    },
    onDrop(e) {
      console.log('放置元素');
    }
  }
}
</script>

拖拽限制与边界控制

可以通过计算位置和边界条件限制拖拽范围。

<template>
  <div 
    ref="draggable"
    class="draggable-item"
    @mousedown="startDrag"
    @mousemove="onDrag"
    @mouseup="stopDrag"
    :style="{ left: position.x + 'px', top: position.y + 'px' }"
  >
    可拖拽元素
  </div>
</template>

<script>
export default {
  data() {
    return {
      isDragging: false,
      position: { x: 0, y: 0 },
      startPos: { x: 0, y: 0 }
    };
  },
  methods: {
    startDrag(e) {
      this.isDragging = true;
      this.startPos = {
        x: e.clientX - this.position.x,
        y: e.clientY - this.position.y
      };
    },
    onDrag(e) {
      if (!this.isDragging) return;

      const newX = e.clientX - this.startPos.x;
      const newY = e.clientY - this.startPos.y;

      // 边界检查
      const container = this.$el.parentElement;
      const maxX = container.clientWidth - this.$el.clientWidth;
      const maxY = container.clientHeight - this.$el.clientHeight;

      this.position.x = Math.max(0, Math.min(newX, maxX));
      this.position.y = Math.max(0, Math.min(newY, maxY));
    },
    stopDrag() {
      this.isDragging = false;
    }
  }
}
</script>

标签: vuedrag
分享给朋友:

相关文章

vue实现开关

vue实现开关

Vue 实现开关组件的方法 使用原生HTML和Vue数据绑定 通过v-model绑定复选框的checked状态,结合CSS样式实现开关效果: <template> <label…

vue 实现fadeout

vue 实现fadeout

Vue 实现淡出效果 在 Vue 中实现淡出(fade-out)效果可以通过 CSS 过渡或动画结合 Vue 的动态渲染功能完成。以下是几种常见方法: 使用 Vue 过渡(Transition)组件…

vue 实现$(id)

vue 实现$(id)

在 Vue 中实现类似 jQuery 的 $(id) 功能,可以通过以下几种方式操作 DOM 元素: 使用 ref 属性 Vue 推荐使用 ref 属性来直接访问 DOM 元素或组件实例。在模板中为…

vue路由实现滑动

vue路由实现滑动

实现 Vue 路由滑动效果的方法 使用 Vue Router 结合 CSS 过渡动画 在 Vue Router 的路由视图组件 <router-view> 上添加过渡效果,结合 CSS 实…

vue实现滑动条

vue实现滑动条

Vue 实现滑动条 在 Vue 中实现滑动条可以通过原生 HTML 的 <input type="range"> 或自定义组件实现。以下是两种常见方法: 使用原生 HTML 滑动条 通过…

vue实现回调

vue实现回调

Vue 实现回调的方法 在 Vue 中实现回调可以通过多种方式,包括使用 props、事件、全局事件总线或 Vuex 等状态管理工具。以下是几种常见的实现方法: 使用 props 传递回调函数 父组…