亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Javascript 拖拽的一些簡單的應用(逐行分析代碼,讓你輕松了拖拽的原理)

2019-11-20 13:19:43
字體:
來源:轉載
供稿:網友

今天我們來看看如何讓拖拽的物體不能拖出某個div之外和拖拽的吸附功能

上次講到我們的拖拽是不可拖出可視區范圍的,在這基礎上我們加個父級的div,不讓他拖出父級。原理和之前的一樣,簡單吧。

html代碼:

<div id="div2">      <div id="div1">      </div>    </div>

css代碼:

<style type="text/css">      #div1 {        width: 100px;        height: 100px;        background: red;        position: absolute;      }      #div2 {        width: 400px;        height: 300px;        background: #CCCCCC;        position: relative;      }    </style>

javascript代碼:

<script type="text/javascript">       // 拖拽空div 低版本的火狐有bug      window.onload = function() {        var oDiv = document.getElementById("div1");        var oDiv2 = document.getElementById("div2");        var disX = 0;        var disY = 0;        oDiv.onmousedown = function(ev) {          var oEvent = ev || event;          disX = oEvent.clientX - oDiv.offsetLeft;          disY = oEvent.clientY - oDiv.offsetTop;          document.onmousemove = function(ev) {            var oEvent = ev || event;            // 存儲div當前的位置            var oDivLeft = oEvent.clientX - disX;            var oDivTop = oEvent.clientY - disY;            if (oDivLeft < 0) {              oDivLeft = 0;            } else if (oDivLeft > oDiv2.offsetWidth - oDiv.offsetWidth) {              oDivLeft = oDiv2.offsetWidth - oDiv.offsetWidth;            }            if (oDivTop < 0) {              oDivTop = 0;            } else if (oDivTop > oDiv2.offsetHeight - oDiv.offsetHeight) {              oDivTop = oDiv2.offsetHeight - oDiv.offsetHeight;            }            oDiv.style.left = oDivLeft + 'px';            oDiv.style.top = oDivTop + 'px';          };          document.onmouseup = function() {            document.onmousemove = null;            document.onmouseup = null;          };          return false; // 阻止默認事件,解決火狐的bug        };      };    </script>

效果圖如下:

簡單吧。

接下來就是如何讓他自動吸附。

其實這個大家會經常用到,比如ps里面有個小窗拖著拖著到頁面邊上的時候,他就會自動吸附上去。

我們這個拖拽怎么才能有這樣的功能呢?

這其實之前將運動的時候提到過,就好比打車你不可能分毫不差的讓司機停在那里,他肯定是停在靠近目的地的地方。

那程序也是一樣的,差不多快到了就直接賦值即可。假設我拖拽的物體離左邊50px的時候,我就認為他到了左邊,那直接賦值為0,他就會自動吸附上去。

原理很簡單,看看代碼如何實現的吧。稍作修改即可

<script type="text/javascript">      window.onload = function() {        var oDiv = document.getElementById("div1");        var oDiv2 = document.getElementById("div2");        var disX = 0;        var disY = 0;        oDiv.onmousedown = function(ev) {          var oEvent = ev || event;          disX = oEvent.clientX - oDiv.offsetLeft;          disY = oEvent.clientY - oDiv.offsetTop;          document.onmousemove = function(ev) {            var oEvent = ev || event;            var oDivLeft = oEvent.clientX - disX;            var oDivTop = oEvent.clientY - disY;            // 當left 小于50 就自動歸0 這樣實現吸附            if (oDivLeft < 50) {              oDivLeft = 0;            } else if (oDivLeft > oDiv2.offsetWidth - oDiv.offsetWidth) {              oDivLeft = oDiv2.offsetWidth - oDiv.offsetWidth;            }            if (oDivTop < 0) {              oDivTop = 0;            } else if (oDivTop > oDiv2.offsetHeight - oDiv.offsetHeight) {              oDivTop = oDiv2.offsetHeight - oDiv.offsetHeight;            }            oDiv.style.left = oDivLeft + 'px';            oDiv.style.top = oDivTop + 'px';          };          document.onmouseup = function() {            document.onmousemove = null;            document.onmouseup = null;          };          return false;         };      };    </script>

下一次會講到高級應用,這些會更加的負責更加的有用。已完善我們的拖拽功能。

比如說圖片的拖拽和文字的選中。比如說我們現在的這個拖拽頁面上就只有一個div,在平時開發中是不會遇到的。

其實在頁面上有東西的情況下,這個拖拽會出現什么問題???

下次會解決 ~ 盡請期待

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品调教chinesegay| 免费不卡在线观看av| 国产网站欧美日韩免费精品在线观看| 成人免费观看a| 欧美激情一二区| 亚洲品质视频自拍网| 狠狠色狠狠色综合日日小说| 国产一区二区三区在线观看网站| 国产视频在线一区二区| 97热在线精品视频在线观看| 最近2019免费中文字幕视频三| 91情侣偷在线精品国产| 亚洲欧美日韩天堂一区二区| 欧美裸体xxxx极品少妇| 欧美激情在线观看视频| 精品久久中文字幕| 久久男人资源视频| 欧美精品激情在线| 91亚洲精品久久久久久久久久久久| 日韩一区二区av| 成人免费淫片aa视频免费| 欧美成人免费小视频| 三级精品视频久久久久| 色妞久久福利网| 国产日韩在线一区| 91精品免费看| 久久精品久久久久电影| 国产精品成人一区| 亚洲毛片在线看| 亚洲一区久久久| 久久99视频免费| 91高清免费在线观看| 国产美女精彩久久| 国产日韩精品视频| 亚洲欧美国产一本综合首页| 久久影视电视剧免费网站| 欧美日韩免费区域视频在线观看| 久久精品夜夜夜夜夜久久| 91在线视频九色| 成人精品一区二区三区电影免费| 韩国国内大量揄拍精品视频| 免费av在线一区| 日韩精品中文字幕在线播放| 91国内产香蕉| 久久久久久网址| 国产99久久精品一区二区永久免费| 亚洲老板91色精品久久| 精品国产91久久久| 亚洲精品国产精品久久清纯直播| 亚洲日本成人网| 久久躁狠狠躁夜夜爽| 91天堂在线视频| 国产视频综合在线| 国产日韩精品视频| 日韩av在线免费播放| 欧美黑人视频一区| 国产精品一区二区在线| 日本久久精品视频| 国产精品成人一区二区| 欧美老女人性视频| 日韩精品免费电影| 成人在线免费观看视视频| 国产福利精品av综合导导航| 欧美在线国产精品| 亚洲精品电影网| 成人午夜在线视频一区| 51精品国产黑色丝袜高跟鞋| 欧美xxxwww| 亚洲午夜激情免费视频| 久久精品成人欧美大片| 久久久久久网址| 日韩av电影院| 成人性生交大片免费观看嘿嘿视频| 精品久久久中文| 亚洲欧美日韩国产中文| 国产精品电影久久久久电影网| 日韩亚洲欧美中文高清在线| 国产日韩精品一区二区| 国产欧美日韩精品在线观看| 欧美第一页在线| 在线观看久久av| 成人中文字幕+乱码+中文字幕| 深夜成人在线观看| 久久免费在线观看| 97视频在线观看亚洲| 亚洲人成亚洲人成在线观看| 久久久国产成人精品| 亚洲女人天堂av| 国产精品美女久久久久av超清| 日本不卡高字幕在线2019| 欧美久久精品午夜青青大伊人| 久久影视电视剧免费网站| 亚洲天堂免费在线| 亚洲美女又黄又爽在线观看| 日韩欧美亚洲成人| 欧美美女操人视频| 91天堂在线视频| 国产亚洲日本欧美韩国| 亚洲二区在线播放视频| 欧洲亚洲妇女av| 国产精品嫩草视频| 久久久久国产一区二区三区| 91精品国产91| 国产亚洲精品久久久优势| 欧美俄罗斯性视频| 国产成人免费91av在线| 亚洲摸下面视频| 久久久女人电视剧免费播放下载| 国产视频在线观看一区二区| 国产精品欧美日韩久久| 国产不卡精品视男人的天堂| 欧美疯狂性受xxxxx另类| 91精品国产高清| 国产成人小视频在线观看| 亚洲欧美日韩视频一区| 日韩精品在线免费观看| 国产成人av在线播放| 国产国产精品人在线视| 国模精品一区二区三区色天香| 97精品国产97久久久久久春色| 疯狂做受xxxx欧美肥白少妇| 欧美一级淫片aaaaaaa视频| 国产一区二区美女视频| 亚洲美女av网站| 国产一区在线播放| 91国内精品久久| 中文字幕日韩精品有码视频| 国产精品久久在线观看| 亚洲国产精品专区久久| 91免费看国产| 国产日韩欧美日韩| 欧美日韩视频在线| 91久久嫩草影院一区二区| 欧美成人亚洲成人| 亚洲精品福利在线观看| 日本一区二区在线免费播放| 日韩中文字幕网| 日韩精品在线观看一区| 欧美老女人在线视频| 最近2019年中文视频免费在线观看| 国产日韩欧美电影在线观看| 欧美成人精品不卡视频在线观看| 亚洲乱码国产乱码精品精| 欧美国产日本高清在线| 一本一道久久a久久精品逆3p| 免费不卡在线观看av| 97色在线观看| 日韩小视频在线观看| 欧美激情乱人伦| 91在线视频一区| 色妞一区二区三区| 国产精品国产福利国产秒拍| 亚洲性生活视频在线观看| www.亚洲一区| 午夜精品免费视频| 中文字幕欧美精品日韩中文字幕| 黄色精品一区二区| 国内精品国产三级国产在线专| 91精品视频在线看| 66m—66摸成人免费视频| 国产裸体写真av一区二区| 久久久久久久电影一区| 日韩在线精品视频| 岛国av午夜精品|