vue+ts實現(xiàn)元素鼠標(biāo)拖動效果
本文實例為大家分享了vue+ts實現(xiàn)元素鼠標(biāo)拖動效果的具體代碼,供大家參考,具體內(nèi)容如下
實現(xiàn)效果

相關(guān)使用屬性
// clientX 鼠標(biāo)相對于瀏覽器左上角x軸的坐標(biāo); 不隨滾動條滾動而改變; // clientY 鼠標(biāo)相對于瀏覽器左上角y軸的坐標(biāo); 不隨滾動條滾動而改變; // element.offsetTop 指 element距離上方或上層控件的位置,整型,單位像素。 // element.offsetLeft 指 element距離左方或上層控件的位置,整型,單位像素。 // element.offsetWidth 指 element控件自身的寬度,整型,單位像素。 // element.offsetHeight 指 element控件自身的高度,整型,單位像素。 // clientHeigh = height + 上下padding // clientWidth = width+左右padding
實現(xiàn)完整代碼
<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鼠標(biāo)相對于瀏覽器左上角x軸的坐標(biāo)-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-----多個參數(shù),返回最小值
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>
參考來源:用JavaScript實現(xiàn)div的鼠標(biāo)拖拽效果
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue項目或網(wǎng)頁上實現(xiàn)文字轉(zhuǎn)換成語音播放功能
這篇文章主要介紹了在vue項目或網(wǎng)頁上實現(xiàn)文字轉(zhuǎn)換成語音,需要的朋友可以參考下2020-06-06
iview form清除校驗狀態(tài)的實現(xiàn)
這篇文章主要介紹了iview form清除校驗狀態(tài)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
vue用elementui寫form表單時,在label里添加空格操作
這篇文章主要介紹了vue用elementui寫form表單時,在label里添加空格操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08
詳解Element-ui NavMenu子菜單使用遞歸生成時使用報錯
這篇文章主要介紹了詳解Element-ui NavMenu子菜單使用遞歸生成時使用報錯,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
vue flex 布局實現(xiàn)div均分自動換行的示例代碼
這篇文章主要介紹了vue flex 布局實現(xiàn)div均分自動換行,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08

