在Vue中如何实现鼠标拖动div的效果,方法是什么
Admin 2022-06-21 群英技术资讯 1249 次浏览
这篇文章给大家介绍了“在Vue中如何实现鼠标拖动div的效果,方法是什么”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。本文实例为大家分享了vue+ts实现元素鼠标拖动效果的具体代码,供大家参考,具体内容如下
实现效果

相关使用属性
// clientX 鼠标相对于浏览器左上角x轴的坐标; 不随滚动条滚动而改变; // clientY 鼠标相对于浏览器左上角y轴的坐标; 不随滚动条滚动而改变; // element.offsetTop 指 element距离上方或上层控件的位置,整型,单位像素。 // element.offsetLeft 指 element距离左方或上层控件的位置,整型,单位像素。 // element.offsetWidth 指 element控件自身的宽度,整型,单位像素。 // element.offsetHeight 指 element控件自身的高度,整型,单位像素。 // clientHeigh = height + 上下padding // clientWidth = width+左右padding
实现完整代码
<template>
<div class="to-do-list" ref="parentBox">
<div class="search-title">
<h1 class="add-bold left-box" style="margin-left:35px">
<a-icon type="unordered-list" style="margin-right: 10px;" />元素拖动
</h1>
</div>
<a-button ref="moveBtn" style="width: 100px;height: 40px;transition:none" class="move-btn" type="primary"
>拖动按钮</a-button
>
</div>
</template>
<script lang="ts">
import { Component, Emit, Inject, Prop, Ref, Vue, Watch } from 'vue-property-decorator';
@Component({
components: {},
})
export default class BriberyInformation extends Vue {
@Ref() readonly moveBtn;
@Ref() readonly parentBox;
btnDown() {
let box = this.moveBtn.$el; //获取button的盒子dom元素
let parentBox = this.parentBox; //获取button父级元素的dom元素
let parentH = parentBox.clientHeight; //获取button父级元素的height
let parentW = parentBox.clientWidth; //获取button父级元素的width
let x, y;
let moveX, moveY; //移动距离
let maxX, maxY; //最大移动距离
let isDrop = false;
box.onmousedown = e => {
x = e.clientX - box.offsetLeft; // e.clientX鼠标相对于浏览器左上角x轴的坐标-button上层控件的位置
y = e.clientY - box.offsetTop;
isDrop = true;
};
document.onmousemove = e => {
if (isDrop) {
e.preventDefault();
moveX = e.clientX - x; //得到距离左边移动距离
moveY = e.clientY - y; //得到距离上边移动距离
//可移动最大距离
maxX = parentW - box.offsetWidth;
maxY = parentH - box.offsetHeight;
//移动的有效距离计算
//console.log(Math.min(-1, 4, 6, 12));//输出-1-----多个参数,返回最小值
moveX = Math.min(maxX, Math.max(0, moveX));
moveY = Math.min(maxY, Math.max(0, moveY));
box.style.left = moveX + 'px';
box.style.top = moveY + 'px';
} else {
return;
}
};
document.onmouseup = e => {
e.preventDefault();
isDrop = false;
};
}
mounted() {
this.btnDown();
}
}
</script>
<style scoped lang="less">
.to-do-list {
position: relative;
min-height: 600px;
max-height: 600px;
width: 600px;
overflow: hidden;
border: 2px solid black;
.move-btn {
position: absolute;
}
}
</style>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文主要介绍了JS原生双栏穿梭选择框的实现示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
判断方法:1、使用“document.getElementById("id值")”语句根据指定id值获取div元素对象;2、利用if语句判断div是否存在,语法“if (div元素对象){//元素存在}else{//元素不存在}”。
目录前言一、forEach(),用于遍历数组,无返回值二、map(),用于遍历数组,返回处理之后的新数组三、every(),用于判断数组中的每一项元素是否都满足条件,返回一个布尔值四、some(),用于判断数组中的是否存在满足条件的元素,返回一个布尔值五、filter(),用于筛选数组中满足条件的元素,返回一个筛选后的
jQuery事件的具体使用是怎样,种类包括哪些?事件响应和触发器是jQuery编程中非常重要的技术,而我们程序员也需要掌握和运用jQuery的各种常见事件操作技巧,这在我们的编程有很重要的作用。
本文主要介绍了 vue全局引入scss,我们在写VUE的时候,会使用scss,也会做一些通用样式,方便使用,在写好的通用样式的时候,每次都要单文件导入,刚开始写的时候,感觉还好,后面工程量大了后,就显得麻烦,那么本文就全局导入scss样式,下面来看详细内容,需要的朋友可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008