国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

服務(wù)器之家 - 編程語言 - JavaScript - js教程 - js面向?qū)ο蠓绞綄?shí)現(xiàn)拖拽效果

js面向?qū)ο蠓绞綄?shí)現(xiàn)拖拽效果

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

這篇文章主要為大家詳細(xì)介紹了js面向?qū)ο蠓绞綄?shí)現(xiàn)拖拽效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了js面向?qū)ο蠓绞綄?shí)現(xiàn)拖拽的具體代碼,供大家參考,具體內(nèi)容如下

拖拽功能的實(shí)現(xiàn)原理:(直接拿走?。?/p>

?
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>

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

js面向?qū)ο蠓绞綄?shí)現(xiàn)拖拽效果

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

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

延伸 · 閱讀

精彩推薦
  • js教程js面向?qū)ο蠓绞綄?shí)現(xiàn)拖拽效果

    js面向?qū)ο蠓绞綄?shí)現(xiàn)拖拽效果

    這篇文章主要為大家詳細(xì)介紹了js面向?qū)ο蠓绞綄?shí)現(xiàn)拖拽效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下...

    web前端的清流7222022-01-25
  • js教程微信小程序?qū)崿F(xiàn)modal彈出框遮罩層組件(可帶文本框)

    微信小程序?qū)崿F(xiàn)modal彈出框遮罩層組件(可帶文本框)

    這篇文章主要給大家介紹了關(guān)于微信小程序?qū)崿F(xiàn)modal彈出框遮罩層組件(可帶文本框)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者...

    BadmintonCode3582021-12-15
  • js教程如何使用原生Js實(shí)現(xiàn)隨機(jī)點(diǎn)名詳解

    如何使用原生Js實(shí)現(xiàn)隨機(jī)點(diǎn)名詳解

    這篇文章主要給大家介紹了關(guān)于如何使用原生Js實(shí)現(xiàn)隨機(jī)點(diǎn)名的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)...

    CV_Di8142021-12-27
  • js教程JS中錨點(diǎn)鏈接點(diǎn)擊平滑滾動(dòng)并自由調(diào)整到頂部位置

    JS中錨點(diǎn)鏈接點(diǎn)擊平滑滾動(dòng)并自由調(diào)整到頂部位置

    這篇文章主要介紹了JS中錨點(diǎn)鏈接點(diǎn)擊平滑滾動(dòng)并自由調(diào)整到頂部位置,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的...

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

    Strve.js開發(fā)一個(gè)屬于自己的庫或框架

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

    前端歷劫之路5912021-12-23
  • js教程JavaScript實(shí)現(xiàn)打字游戲

    JavaScript實(shí)現(xiàn)打字游戲

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

    一顆不甘墜落的流星3902022-01-21
  • js教程JS實(shí)現(xiàn)簡單抖動(dòng)效果

    JS實(shí)現(xiàn)簡單抖動(dòng)效果

    這篇文章給大家結(jié)束了通過js實(shí)現(xiàn)抖動(dòng)效果,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友參考下吧...

    catEatBird9152022-01-12
  • js教程JS實(shí)現(xiàn)百度搜索框

    JS實(shí)現(xiàn)百度搜索框

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

    張先生的blog9182022-01-24
主站蜘蛛池模板: 国产成人精品免高潮在线观看 | 国产精品一区二 | 欧美视频精品 | 久久久久久国产精品mv | 人人超碰97 | 欧美精品一区二区视频 | 成人深夜福利 | 亚洲成人一区二区三区 | 艹逼短视频 | 欧美一区二区三 | www中文字幕 | 一区二区三区在线 | 黄色一级片免费 | 久久久国产一区二区三区 | 国产精品久久久久久久久久久久冷 | 中文字幕免费视频 | 亚洲成人精品av | 香蕉视频三级 | 久草av在线播放 | 人人干视频 | 成年网站视频 | 精品成人av一区二区在线播放 | 久久久久久久久国产成人免费 | 天天草天天干 | 免费视频一区二区 | 亚洲国产精品久久久久 | 亚洲一区二区美女 | 欧美一级做a爰片久久高潮 免费在线毛片 | a视频在线 | 国产美女视频网站 | 日本丶国产丶欧美色综合 | 免费岛国视频 | 成人在线观看av | 91色乱码一区二区三区 | 成人一级黄色大片 | 成人福利网 | 亚洲一区二区三区高清 | 日韩精品www | 日韩一区二区三区在线视频 | 91精品国产色综合久久 | 欧美日本韩国一区二区 |