vue+ts实现元素鼠标拖动效果

发布时间:2022-04-16 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了vue+ts实现元素鼠标拖动效果脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例为大家分享了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>

参考来用JavaScript实现div的鼠标拖拽效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本宝典。

脚本宝典总结

以上是脚本宝典为你收集整理的vue+ts实现元素鼠标拖动效果全部内容,希望文章能够帮你解决vue+ts实现元素鼠标拖动效果所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:vue