vue 鼠标在父元素内移动,子元素跟随鼠标移动,且子元素不能超出父元素边框
时间: 2023-11-30 10:02:18 浏览: 130
你可以使用 @mousemove
监听鼠标移动事件,然后通过计算鼠标位置和父元素位置的差值,来设置子元素的位置。
具体实现步骤如下:
- 在父元素上添加
@mousemove
监听事件,获取鼠标位置event.pageX
和event.pageY
以及父元素位置parentNode.offsetLeft
和parentNode.offsetTop
。 - 计算鼠标位置和父元素位置的差值
deltaX
和deltaY
。 - 判断子元素的位置是否超出父元素的边界,如果超出则设置子元素的位置为父元素的边界位置。
- 否则,设置子元素的位置为鼠标位置和父元素位置的差值。
代码示例:
<template>
<div class="parent" @mousemove="handleMouseMove">
<div class="child" :style="{left: childLeft + 'px', top: childTop + 'px'}"></div>
</div>
</template>
<script>
export default {
data() {
return {
childLeft: 0,
childTop: 0
}
},
methods: {
handleMouseMove(event) {
const parentNode = event.currentTarget
const mouseX = event.pageX
const mouseY = event.pageY
const parentX = parentNode.offsetLeft
const parentY = parentNode.offsetTop
const deltaX = mouseX - parentX
const deltaY = mouseY - parentY
const childWidth = 100 // 子元素宽度
const childHeight = 100 // 子元素高度
const maxX = parentNode.clientWidth - childWidth // 子元素最大可移动的横向距离
const maxY = parentNode.clientHeight - childHeight // 子元素最大可移动的纵向距离
let childLeft = deltaX
let childTop = deltaY
if (childLeft < 0) {
childLeft = 0
} else if (childLeft > maxX) {
childLeft = maxX
}
if (childTop < 0) {
childTop = 0
} else if (childTop > maxY) {
childTop = maxY
}
this.childLeft = childLeft
this.childTop = childTop
}
}
}
</script>
<style>
.parent {
position: relative;
width: 300px;
height: 300px;
border: 1px solid #ccc;
}
.child {
position: absolute;
width: 100px;
height: 100px;
background-color: red;
}
</style>
相关推荐
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt=".zip"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="-"