中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用vue+ts實現元素鼠標拖動效果

發布時間:2021-11-08 09:05:01 來源:億速云 閱讀:261 作者:iii 欄目:開發技術

這篇文章主要講解了“怎么用vue+ts實現元素鼠標拖動效果”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么用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">
      <h2 class="add-bold left-box" >
        <a-icon type="unordered-list"  />元素拖動
      </h2>
    </div>
    <a-button ref="moveBtn"  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>

感謝各位的閱讀,以上就是“怎么用vue+ts實現元素鼠標拖動效果”的內容了,經過本文的學習后,相信大家對怎么用vue+ts實現元素鼠標拖動效果這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

江陵县| 三门县| 双辽市| 南川市| 台北市| 临高县| 临漳县| 小金县| 玉环县| 久治县| 黎川县| 邢台县| 吉林省| 雅安市| 阜城县| 钟山县| 循化| 晋州市| 利津县| 内江市| 通化市| 宁津县| 辉县市| 从化市| 张家界市| 镇远县| 沙洋县| 陆良县| 彭泽县| 甘孜| 麦盖提县| 尖扎县| 南丹县| 大丰市| 汾西县| 安康市| 醴陵市| 巴彦淖尔市| 德令哈市| 利辛县| 左云县|