一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - js教程 - js面向對象方式實現拖拽效果

js面向對象方式實現拖拽效果

2022-01-25 16:17web前端的清流 js教程

這篇文章主要為大家詳細介紹了js面向對象方式實現拖拽效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了js面向對象方式實現拖拽的具體代碼,供大家參考,具體內容如下

拖拽功能的實現原理:(直接拿走!)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
<!DOCTYPE html>
<html lang="en">
 
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <style>
    #box {
      position: absolute;
      left: 100px;
      top: 100px;
      width: 100px;
      height: 100px;
      background: red;
    }
 
    #box2 {
      position: absolute;
      left: 200px;
      top: 200px;
      width: 100px;
      height: 100px;
      background: green;
    }
  </style>
</head>
 
<body>
  <div id="box">文字</div>
  <div id="box2">文字</div>
</body>
<script>
  class Drag {
    startMouse = {};
    startEl = {};
    #el = null;
    constructor(el, option) {
      this.#el = el;
      this.option = option;
      this.start();
    }
    start() {
      let move = (e) => {
        this.move(e)
      }
      this.#el.addEventListener('mousedown', (e) => {
        this.startMouse = {
          x: e.clientX,
          y: e.clientY,
        }
        this.ondragstart && this.ondragstart(e)
        this.startEl = this.getOffset();
        document.addEventListener('mousemove', move);
        document.addEventListener('mouseup', (e) => {
          document.removeEventListener('mousemove', move);
          this.end(e);
        }, {
          once: true
        })
        e.preventDefault();
 
      })
    }
    move(e) {
      let nowMouse = {
        x: e.clientX,
        y: e.clientY,
      }
      let disMouse = {
        x: nowMouse.x - this.startMouse.x,
        y: nowMouse.y - this.startMouse.y
      }
      this.ondrag && this.ondrag(e)
      this.setOffset(disMouse)
    }
    end(e) {
      this.ondragend && this.ondragend(e)
    }
    getOffset() {
      return {
        x: parseFloat(getComputedStyle(this.#el)["left"]),
        y: parseFloat(getComputedStyle(this.#el)["top"])
      }
    }
    setOffset(dis) {
      this.#el.style.left = this.startEl.x + dis.x + 'px'
      this.#el.style.top = this.startEl.y + dis.y + 'px'
    }
  }
  let box = document.querySelector("#box");
  let box2 = document.querySelector("#box2");
  let d = new Drag(box);
  let d2 = new Drag(box2);
  let clonex = null;
  d2.ondragstart = (e) => {
    clonex = box2.cloneNode(true);
    document.body.appendChild(clonex)
    box2.style.opacity = 0.5
  }
  d2.ondragend = () => {
    document.body.removeChild(clonex);
    box2.style.opacity = 1
  }
</script>
 
</html>

最終效果(拖動的為綠色塊)

js面向對象方式實現拖拽效果

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/weixin_43140300/article/details/114268771

延伸 · 閱讀

精彩推薦
  • js教程js面向對象方式實現拖拽效果

    js面向對象方式實現拖拽效果

    這篇文章主要為大家詳細介紹了js面向對象方式實現拖拽效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    web前端的清流7222022-01-25
  • js教程微信小程序實現modal彈出框遮罩層組件(可帶文本框)

    微信小程序實現modal彈出框遮罩層組件(可帶文本框)

    這篇文章主要給大家介紹了關于微信小程序實現modal彈出框遮罩層組件(可帶文本框)的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者...

    BadmintonCode3582021-12-15
  • js教程如何使用原生Js實現隨機點名詳解

    如何使用原生Js實現隨機點名詳解

    這篇文章主要給大家介紹了關于如何使用原生Js實現隨機點名的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習...

    CV_Di8142021-12-27
  • js教程JS中錨點鏈接點擊平滑滾動并自由調整到頂部位置

    JS中錨點鏈接點擊平滑滾動并自由調整到頂部位置

    這篇文章主要介紹了JS中錨點鏈接點擊平滑滾動并自由調整到頂部位置,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的...

    是這樣的三月6392022-01-19
  • js教程Strve.js開發一個屬于自己的庫或框架

    Strve.js開發一個屬于自己的庫或框架

    Strve.js是一個可以將字符串轉換為視圖的JS庫。這里的字符串指的是模板字符串,所以你僅需要在JavaScript中開發視圖。Strve.js不僅易于上手,還便于靈活拆裝...

    前端歷劫之路5912021-12-23
  • js教程JavaScript實現打字游戲

    JavaScript實現打字游戲

    這篇文章主要為大家詳細介紹了JavaScript實現打字游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    一顆不甘墜落的流星3902022-01-21
  • js教程JS實現簡單抖動效果

    JS實現簡單抖動效果

    這篇文章給大家結束了通過js實現抖動效果,非常不錯,具有參考借鑒價值,感興趣的朋友參考下吧...

    catEatBird9152022-01-12
  • js教程JS實現百度搜索框

    JS實現百度搜索框

    這篇文章主要為大家詳細介紹了JS實現百度搜索框,實時返回搜索建議項,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參...

    張先生的blog9182022-01-24
主站蜘蛛池模板: 成人啪精品视频免费网站 | 成人资源在线观看 | 日本一道一区二区免费看 | 91精品国产91久久久久久麻豆 | 91色在线观看国产 | 视频一区二区三区在线观看 | china精品对白普通话 | 视频在线视频免费观看 | 成人性爱视频在线观看 | 国内自拍第1页 | 精品无码久久久久久久动漫 | 亚洲欧美日韩中文字幕网址 | 国产成人精品免费2021 | 天天天天天天天操 | 韩日视频在线观看 | 纲手被强喷水羞羞漫画 | 久久综合给会久久狠狠狠 | 无套大战白嫩乌克兰美女 | 亚洲男人的天堂网站 | 国产裸舞在线一区二区 | 日本一卡二卡3卡四卡无卡网址 | 久久国产加勒比精品无码 | 精品国产免费第一区二区 | 俺去俺也在线www色官网 | 日韩高清在线免费观看 | 国产精品久久亚洲一区二区 | 人人人人看人人人做人人 | 国产免费久久精品 | 亚洲冬月枫中文字幕在线看 | 国产成人高清精品免费5388密 | 精品欧美一区二区在线观看欧美熟 | 59日本人xxxxxxxxx69 | 九九精品99久久久香蕉 | 激情视频网址 | 毛片免费的 | 鬼吹灯天星术在线高清观看 | 884aa草莓视频 | 亚洲精品午夜在线观看 | 日本一卡二卡3卡四卡网站精品 | 亚洲qvod图片区电影 | 国产欧美精品一区二区三区四区 |