国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Javascript 拖拽的一些高級(jí)的應(yīng)用(逐行分析代碼,讓你輕松了拖拽的原理)

2019-11-20 13:19:45
字體:
供稿:網(wǎng)友

我們看看之前的拖拽在周圍有東西的時(shí)候會(huì)出現(xiàn)什么問題? 在高級(jí)瀏覽器中不會(huì)有啥問題,我們放到IE7下面測試一下,問題就出來了。如圖

我們可以很清楚的看到,文字都已經(jīng)被選中了。那這個(gè)用戶體驗(yàn)很不好,用起來也不方便。順便提一下,我們之前加了一個(gè)return false;幫我們解決了很多問題,如果去掉這個(gè)的話,chrome也會(huì)出現(xiàn)一樣的問題。那么也就是說這個(gè)return false;可以解決chrome ff IE9+ 這些瀏覽器的問題。

實(shí)際上在我們開發(fā)中,頁面上會(huì)有許多的元素組成,不可能就一個(gè)div,在你拖動(dòng)的時(shí)候其他地方是不會(huì)被選中的,比如說百度地圖,大家可以玩玩。
那我們?nèi)绾巫龅竭@樣子的一個(gè)拖拽呢?能夠解決IE7的問題呢?

解決方案:

我們可以用一個(gè)小技巧來解決,這個(gè)技巧只有在IE6-8支持,實(shí)際上就能解決我們的問題,因?yàn)槠渌臑g覽器用return false; 就夠了。下面看看是什么技巧

就是事件捕獲??! 簡單說明下 附上代碼

<title></title>    <script type="text/javascript">      window.onload=function(){        var oBtn=document.getElementById("btn");        oBtn.onclick=function(){          alert(1);        };        // 網(wǎng)頁上所有地方的上的事件都集中到一個(gè)按鈕身上 IE 專用        oBtn.setCapture(); // 點(diǎn)擊哪里都是彈a      }    </script>  </head>  <body>    <input type="button" id="btn" value="按鈕" />  </body>

實(shí)際上就是頁面上所有地方上的事件都集中到一點(diǎn),點(diǎn)擊頁面任何位置都會(huì)彈出a,也就是setCapture()作用。

把所有事件都集中到一個(gè)按鈕來處理??! 這個(gè)就只有IE兼容?。?/p>

這樣,讓我來看看如何修改之前的代碼。。。。

我們首先把所有的document改回div,記不記得我們之前講過因?yàn)槭髽?biāo)拖動(dòng)的快點(diǎn)就容易拖出div,所以把事件都加在document上。

而現(xiàn)在就不必這樣做了,給我們之前的div加上一個(gè)setCapture()看看效果。

<body>    IE 7 中的文字會(huì)被選中 ,    <br />如果不加return false chrome ff 也會(huì)有這樣的問題 asdsadad    <br />    <div id="div1">      asdsadad asdsadad asdsadad    </div>    asdsadadasdsadadasdsadad  </body>
<style type="text/css">      #div1 {        width: 200px;        height: 200px;        background: red;        position: absolute;      }    </style>
<script type="text/javascript">     // 拖拽空div 低版本的火狐有bug   window.onload = function() {    var oDiv = document.getElementById("div1");    var disX = 0;    var disY = 0;    oDiv.onmousedown = function(ev) {     var oEvent = ev || event;     disX = oEvent.clientX - oDiv.offsetLeft;     disY = oEvent.clientY - oDiv.offsetTop;     oDiv.onmousemove = function(ev) {      var oEvent = ev || event;      var oDivLeft = oEvent.clientX - disX;      var oDivTop = oEvent.clientY - disY;      oDiv.style.left = oDivLeft + 'px';      oDiv.style.top = oDivTop + 'px';     };     oDiv.onmouseup = function() {      oDiv.onmousemove = null;      oDiv.onmouseup = null;     };     oDiv.setCapture();     return false; // 阻止默認(rèn)事件,解決火狐的bug    };   };  </script>

這個(gè)時(shí)候?qū)嶋H上我們拖動(dòng)在快也不會(huì)出現(xiàn)鼠標(biāo)拖出Div的問題了。 實(shí)際上加了setCapture()以后,整個(gè)網(wǎng)頁上所有的事件都會(huì)聚集在這一個(gè)div上面。

其實(shí)現(xiàn)在,這個(gè)文字就不會(huì)被選中了。為什么呢? 因?yàn)楝F(xiàn)在網(wǎng)頁上的文字,圖片的所有事件都在div上了,他們已經(jīng)得不到事件了!所以自然他們就不會(huì)被選中了。

當(dāng)然現(xiàn)在又有個(gè)問題????你會(huì)發(fā)現(xiàn)當(dāng)你要試圖去選中那些文字的時(shí)候,就選不中了。

如何是好,事件都集中在div上了。。。!!!!!

所以呢,其實(shí)這個(gè)setCapture()就像一把鎖,現(xiàn)在都鎖住了,事件都在div上面,現(xiàn)在解鎖就可以了 那相對應(yīng)的就有 releaseCapture();

releaseCapture(); 就是釋放捕獲。 實(shí)際上在鼠標(biāo)抬起的時(shí)候加上就可以了。

window.onload = function() {    var oDiv = document.getElementById("div1");    var disX = 0;    var disY = 0;    oDiv.onmousedown = function(ev) {     var oEvent = ev || event;     disX = oEvent.clientX - oDiv.offsetLeft;     disY = oEvent.clientY - oDiv.offsetTop;     oDiv.onmousemove = function(ev) {      var oEvent = ev || event;      var oDivLeft = oEvent.clientX - disX;      var oDivTop = oEvent.clientY - disY;      oDiv.style.left = oDivLeft + 'px';      oDiv.style.top = oDivTop + 'px';     };     oDiv.onmouseup = function() {      oDiv.onmousemove = null;      oDiv.onmouseup = null;      oDiv.releaseCapture();     };     oDiv.setCapture();     return false; // 阻止默認(rèn)事件,解決火狐的bug    };   };

現(xiàn)在就能解決文字選中的問題了。 最后我們坐下兼容,實(shí)際上來說這個(gè)setCapture() 是不兼容的,放在其他瀏覽器就錯(cuò)了。

那么很簡單, 我們只要合并這次與上一次的代碼就可以了,兼容嘛 做個(gè)if判斷就好。最后附上整理好的代碼

<script type="text/javascript">      window.onload = function() {        var oDiv = document.getElementById("div1");        var disX = 0;        var disY = 0;        oDiv.onmousedown = function(ev) {          var oEvent = ev || event;          disX = oEvent.clientX - oDiv.offsetLeft;          disY = oEvent.clientY - oDiv.offsetTop;          if (oDiv.setCapture) {            oDiv.onmousemove = mouseMove;            oDiv.onmouseup = mouseUp;            oDiv.setCapture(); // IE 7 下文字就不會(huì)被選中 其實(shí)就是文字或圖片得不到事件          } else {            document.onmousemove = mouseMove;            document.onmouseup = mouseUp;          }          function mouseMove(ev) {            var oEvent = ev || event;            var oDivLeft = oEvent.clientX - disX;            var oDivTop = oEvent.clientY - disY;            oDiv.style.left = oDivLeft + 'px';            oDiv.style.top = oDivTop + 'px';          }          function mouseUp(ev) {            this.onmousemove = null;            this.onmouseup = null;            if (oDiv.releaseCapture) {              oDiv.releaseCapture(); // 釋放捕獲            }          }          return false; // 阻止默認(rèn)事件,解決火狐的bug        };      };    </script>

好了,都搞定了 O(∩_∩)O哈哈~

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 金溪县| 娄烦县| 余干县| 连南| 祁阳县| 教育| 民丰县| 德钦县| 钟祥市| 石棉县| 龙胜| 潮安县| 平昌县| 丁青县| 罗定市| 本溪| 齐河县| 沁水县| 孝感市| 双江| 新兴县| 夏河县| 博客| 隆尧县| 黄山市| 台前县| 白河县| 奎屯市| 军事| 通渭县| 南澳县| 岳池县| 湖口县| 民权县| 巴林左旗| 伊宁市| 布尔津县| 竹北市| 尚义县| 吉水县| 沂南县|