在指定范围内拖拽

本文介绍了如何在Vue.js中实现元素的拖拽功能,并限制拖拽范围。通过监听鼠标事件,计算鼠标与元素的相对位置,更新元素的left和top样式属性,实现元素在指定容器内的移动。示例代码展示了使用v-for遍历生成多个可拖拽元素,并绑定点击和拖拽事件的过程。
摘要由CSDN通过智能技术生成

<template>

  <div>

    <div id="dragBox">

      <div v-for="(item,index) in list" :key="index" class="box1" :style="{left:(index*60 +50)+'px'}"  :id="'a'+index" @click="btnclick(index)">点击{ {index}}</div>

    </div>

  </div>

</template>

<script>

  export default{

    data() {

      return{

        list:[1,2,3,4,5],

        isDrag: false

      }

    },

    created() {

    },

    mounted() {

    },

    methods:{

      // 点击元素事件

      btnclick(index) {

        // 打印ID值

        console.log('a'+index)

        // 对多个元素绑定拖拽事件,要先点击,然后才能拖拽&

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以通过以下步骤实现拖拽范围的限定: 1. 给指定类名的 div 添加一个事件监听器,监听鼠标按下事件。 ``` const dragArea = document.querySelector('.drag-area'); dragArea.addEventListener('mousedown', dragStart); ``` 2. 在鼠标按下事件中获取拖拽元素和鼠标的初始位置,并给拖拽元素添加一个类名。 ``` let dragItem = null; let dragOffsetX = 0; let dragOffsetY = 0; function dragStart(e) { if (e.target.classList.contains('drag-item')) { dragItem = e.target; dragOffsetX = e.clientX - dragItem.offsetLeft; dragOffsetY = e.clientY - dragItem.offsetTop; dragItem.classList.add('dragging'); } } ``` 3. 给 document 添加一个事件监听器,监听鼠标移动事件和鼠标松开事件。 ``` document.addEventListener('mousemove', drag); document.addEventListener('mouseup', dragEnd); ``` 4. 在鼠标移动事件中计算拖拽元素的位置,并限定拖拽范围指定类名 div 的第一层子节点范围内。 ``` function drag(e) { if (dragItem) { const dragLeft = e.clientX - dragOffsetX; const dragTop = e.clientY - dragOffsetY; const parentRect = dragArea.getBoundingClientRect(); const childRect = dragItem.getBoundingClientRect(); if (dragLeft > parentRect.left && dragLeft + childRect.width < parentRect.right && dragTop > parentRect.top && dragTop + childRect.height < parentRect.bottom) { dragItem.style.left = dragLeft + 'px'; dragItem.style.top = dragTop + 'px'; } } } ``` 5. 在鼠标松开事件中移除拖拽元素的类名。 ``` function dragEnd() { if (dragItem) { dragItem.classList.remove('dragging'); dragItem = null; } } ``` 6. 对于指定类名 div 的第二层子节点,可以在事件监听器中添加一个判断条件,如果是第二层子节点,则不执行拖拽事件。 ``` dragArea.addEventListener('mousedown', function(e) { if (e.target.classList.contains('drag-item')) { if (e.target.parentNode.parentNode !== dragArea) { return; } dragStart(e); } }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值