Javascript 拖拽的一些高級(jí)的應(yīng)用(逐行分析代碼,讓你輕松了拖拽的原理)
我們看看之前的拖拽在周圍有東西的時(shí)候會(huì)出現(xiàn)什么問(wèn)題? 在高級(jí)瀏覽器中不會(huì)有啥問(wèn)題,我們放到IE7下面測(cè)試一下,問(wèn)題就出來(lái)了。如圖
我們可以很清楚的看到,文字都已經(jīng)被選中了。那這個(gè)用戶體驗(yàn)很不好,用起來(lái)也不方便。順便提一下,我們之前加了一個(gè)return false;幫我們解決了很多問(wèn)題,如果去掉這個(gè)的話,chrome也會(huì)出現(xiàn)一樣的問(wèn)題。那么也就是說(shuō)這個(gè)return false;可以解決chrome ff IE9+ 這些瀏覽器的問(wèn)題。
實(shí)際上在我們開(kāi)發(fā)中,頁(yè)面上會(huì)有許多的元素組成,不可能就一個(gè)div,在你拖動(dòng)的時(shí)候其他地方是不會(huì)被選中的,比如說(shuō)百度地圖,大家可以玩玩。
那我們?nèi)绾巫龅竭@樣子的一個(gè)拖拽呢?能夠解決IE7的問(wèn)題呢?
解決方案:
我們可以用一個(gè)小技巧來(lái)解決,這個(gè)技巧只有在IE6-8支持,實(shí)際上就能解決我們的問(wèn)題,因?yàn)槠渌臑g覽器用return false; 就夠了。下面看看是什么技巧
就是事件捕獲??! 簡(jiǎn)單說(shuō)明下 附上代碼
<title></title> <script type="text/javascript"> window.onload=function(){ var oBtn=document.getElementById("btn"); oBtn.onclick=function(){ alert(1); }; // 網(wǎng)頁(yè)上所有地方的上的事件都集中到一個(gè)按鈕身上 IE 專用 oBtn.setCapture(); // 點(diǎn)擊哪里都是彈a } </script> </head> <body> <input type="button" id="btn" value="按鈕" /> </body>
實(shí)際上就是頁(yè)面上所有地方上的事件都集中到一點(diǎn),點(diǎn)擊頁(yè)面任何位置都會(huì)彈出a,也就是setCapture()作用。
把所有事件都集中到一個(gè)按鈕來(lái)處理?。?這個(gè)就只有IE兼容??!
這樣,讓我來(lái)看看如何修改之前的代碼。。。。
我們首先把所有的document改回div,記不記得我們之前講過(guò)因?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ì)有這樣的問(wèn)題 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的問(wèn)題了。 實(shí)際上加了setCapture()以后,整個(gè)網(wǎng)頁(yè)上所有的事件都會(huì)聚集在這一個(gè)div上面。
其實(shí)現(xiàn)在,這個(gè)文字就不會(huì)被選中了。為什么呢? 因?yàn)楝F(xiàn)在網(wǎng)頁(yè)上的文字,圖片的所有事件都在div上了,他們已經(jīng)得不到事件了!所以自然他們就不會(huì)被選中了。
當(dāng)然現(xiàn)在又有個(gè)問(wèn)題????你會(huì)發(fā)現(xiàn)當(dāng)你要試圖去選中那些文字的時(shí)候,就選不中了。
如何是好,事件都集中在div上了。。。!!!!!
所以呢,其實(shí)這個(gè)setCapture()就像一把鎖,現(xiàn)在都鎖住了,事件都在div上面,現(xiàn)在解鎖就可以了 那相對(duì)應(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)在就能解決文字選中的問(wèn)題了。 最后我們坐下兼容,實(shí)際上來(lái)說(shuō)這個(gè)setCapture() 是不兼容的,放在其他瀏覽器就錯(cuò)了。
那么很簡(jiǎn)單, 我們只要合并這次與上一次的代碼就可以了,兼容嘛 做個(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哈哈~
相關(guān)文章
基于javascript實(shí)現(xiàn)瀏覽器滾動(dòng)條快到底部時(shí)自動(dòng)加載數(shù)據(jù)
這篇文章主要介紹了基于javascript實(shí)現(xiàn)瀏覽器滾動(dòng)條快到底部時(shí)自動(dòng)加載數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2015-11-11JavaScript函數(shù)的4種調(diào)用方法詳解
了解函數(shù)的調(diào)用過(guò)程有助于深入學(xué)習(xí)與分析JavaScript代碼。本文是JavaScript高級(jí)這個(gè)系列中的第三篇文章,主要介紹JavaScript中函數(shù)的四種使用形式2014-04-04uniapp中table表格設(shè)置寬度無(wú)效的原因以及解決方法
項(xiàng)目中遇到table表格單元格不整齊、錯(cuò)位等情況,下面這篇文章主要給大家介紹了關(guān)于uniapp中table表格設(shè)置寬度無(wú)效的原因以及解決方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04談?wù)勎覍?duì)JavaScript原型和閉包系列理解(隨手筆記8)
這篇文章主要介紹了談?wù)勎覍?duì)JavaScript原型和閉包系列理解(隨手筆記8)的相關(guān)資料,需要的朋友可以參考下2015-12-12JS實(shí)現(xiàn)的進(jìn)制轉(zhuǎn)換,浮點(diǎn)數(shù)相加,數(shù)字判斷操作示例
這篇文章主要介紹了JS實(shí)現(xiàn)的進(jìn)制轉(zhuǎn)換,浮點(diǎn)數(shù)相加,數(shù)字判斷操作,結(jié)合實(shí)例形式分析了JavaScript數(shù)值運(yùn)算、判斷相關(guān)操作技巧,需要的朋友可以參考下2019-11-11js學(xué)習(xí)總結(jié)_基于數(shù)據(jù)類型檢測(cè)的四種方式(必看)
下面小編就為大家?guī)?lái)一篇js學(xué)習(xí)總結(jié)_基于數(shù)據(jù)類型檢測(cè)的四種方式(必看)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07JavaScript如何讓select選擇框可輸入和可下拉選擇
我們知道一般select下拉框是只能選擇的,而有時(shí)我們會(huì)遇到下拉框中沒(méi)有要選擇的信息項(xiàng)或者下拉選項(xiàng)特別多時(shí),需要允許用戶輸入想要的內(nèi)容,這篇文章主要給大家介紹了關(guān)于JavaScript如何讓select選擇框可輸入和可下拉選擇的相關(guān)資料,需要的朋友可以參考下2023-10-10javascript中IE瀏覽器不支持NEW DATE()帶參數(shù)的解決方法
在火狐下 可以正常取得時(shí)間,在IE7下 卻是 NaN。糾結(jié)老長(zhǎng)時(shí)間,放棄了new date 然后再老外的論壇中找了一段段代碼可以兼容所有瀏覽器的格式化日期代碼2012-03-03