亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript實現(xiàn)拖拽功能

 更新時間:2020年02月11日 09:40:21   作者:xiaoba_598  
這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)拖拽功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了JavaScript實現(xiàn)拖拽功能的具體代碼,供大家參考,具體內(nèi)容如下

盒子拖拽—運用到的有onmousedown事件,onmousemove事件以及onmouseup事件

1、當(dāng)鼠標(biāo)點擊下去的時候我們需要獲取鼠標(biāo)所在位置的橫縱坐標(biāo),然后獲取盒子的離頁面的橫縱方向的距離
2、計算出鼠標(biāo)相對盒子的距離
3、當(dāng)鼠標(biāo)移動的時候,獲取鼠標(biāo)移動的距離,在永鼠標(biāo)此刻的位置減去鼠標(biāo)相對盒子的距離,獲得的是盒子此刻的坐標(biāo)位置
4、將這個位置賦值給盒子
5、鼠標(biāo)抬起,清除鼠標(biāo)移動事件;

代碼:

<!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>鼠標(biāo)拖拽</title>
 <style>
  .box{
   background-color: pink;
   width:200px;
   height:200px;
   border-radius: 50%;
   position: absolute;
   top:20px;
   left:100px;
  }
 </style>
</head>
<body>
 <div class="box">

 </div>
 <script>
  window.onload = function(){
   var box = document.getElementsByClassName('box')[0];
   function drag (ele){
    ele.onmousedown = function(e){
     var e = e || window.event; 
     //此處是為了兼容IE,因為IE中事件對象是作為全局對象( window.event )存在的;
     var pageX = e.pageX || e.clientX + document.documentElement.scrollLeft;
     var pageY = e.pageY || e.clientY + document.documentElement.scrollTop;
     //獲取鼠標(biāo)相對盒子的位置;
     var boxX = pageX - box.offsetLeft;
     var boxY = pageY - box.offsetTop;
     document.onmousemove = function(e){
      var e = e || window.event;
      var pageX = e.pageX || e.clientX + document.documentElement.scrollLeft;
      var pageY = e.pageY || e.clientY + document.documentElement.scrollTop;
      //將鼠標(biāo)當(dāng)前的坐標(biāo)值減去鼠標(biāo)相對盒子的位置,得到盒子當(dāng)時的位置并將其賦值給盒子,實現(xiàn)移動效果
      box.style.left = pageX - boxX +'px';
      box.style.top = pageY - boxY + 'px';
     }
    };
    document.onmouseup = function () {
     //清除盒子的移動事件;
     document.onmousemove = null;
    };
   } ;
   drag(box)
  }
 </script>
</body>
</html>

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

相關(guān)文章

  • JavaScript彈出窗口方法匯總

    JavaScript彈出窗口方法匯總

    這篇文章主要介紹了JavaScript彈出窗口方法,非常實用的功能,需要的朋友可以參考下
    2014-08-08
  • 分享自己用JS做的掃雷小游戲

    分享自己用JS做的掃雷小游戲

    引用了jQuery,節(jié)省了很多鼠標(biāo)點擊上的判斷。界面顯然都是照搬Windows的掃雷啦,詳細的內(nèi)容注釋里都有,感興趣的朋友參考下吧
    2016-02-02
  • js實現(xiàn)上一頁下一頁的效果【附代碼】

    js實現(xiàn)上一頁下一頁的效果【附代碼】

    下面小編就為大家?guī)硪黄猨s實現(xiàn)上一頁下一頁的效果【附代碼】。小編覺得非常不錯?,F(xiàn)在分享給大家。希望能給大家一個參考。
    2016-03-03
  • Javascript操作select控件代碼實例

    Javascript操作select控件代碼實例

    這篇文章主要介紹了Javascript操作select控件代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-02-02
  • canvas 繪制圓形時鐘

    canvas 繪制圓形時鐘

    本文主要分享了利用canvas如何繪制圓形時鐘的示例代碼,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • 總結(jié)分享10 個超棒的 JavaScript 簡寫技巧

    總結(jié)分享10 個超棒的 JavaScript 簡寫技巧

    這篇文章主要總結(jié)分享10 個超棒的 JavaScript 簡寫技巧,有合并數(shù)組、克隆數(shù)組、解構(gòu)賦值、模板字面量等技巧,需要的朋友可以參考一下
    2022-06-06
  • javascript實現(xiàn)貪吃蛇小游戲思路

    javascript實現(xiàn)貪吃蛇小游戲思路

    這篇文章主要為大家詳細介紹了javascript實現(xiàn)貪吃蛇思路小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • javascript中使用replaceAll()函數(shù)實現(xiàn)字符替換的方法

    javascript中使用replaceAll()函數(shù)實現(xiàn)字符替換的方法

    第一次發(fā)現(xiàn)JavaScript中replace()?方法如果直接用str.replace("-","!")?只會替換第一個匹配的字符.
    2010-12-12
  • 微信小程序緩存支持二次開發(fā)封裝實現(xiàn)解析

    微信小程序緩存支持二次開發(fā)封裝實現(xiàn)解析

    這篇文章主要介紹了微信小程序緩存支持二次開發(fā)封裝實現(xiàn)解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-12-12
  • Js冒泡事件詳解及阻止示例

    Js冒泡事件詳解及阻止示例

    如果某元素定義了事件A,如click事件,如果觸發(fā)了事件之后,沒有阻止冒泡事件,那么事件將向父級元素傳播
    2014-03-03

最新評論