日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

Javascript 拖拽的一些高级的应用——逐行分析代码,让你轻松了解拖拽的原理...

發(fā)布時間:2023/11/27 生活经验 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Javascript 拖拽的一些高级的应用——逐行分析代码,让你轻松了解拖拽的原理... 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

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

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

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

解決方案:

我們可以用一個小技巧來解決,這個技巧只有在IE6-8支持,實際上就能解決我們的問題,因為其他的瀏覽器用return false; 就夠了。下面看看是什么技巧

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

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

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

把所有事件都集中到一個按鈕來處理!! 這個就只有IE兼容!!

?

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

?

我們首先把所有的document改回div,記不記得我們之前講過因為鼠標拖動的快點就容易拖出div,所以把事件都加在document上。

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

<body>IE 7 中的文字會被選中 ,<br />如果不加return false chrome ff 也會有這樣的問題 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 低版本的火狐有bugwindow.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; // 阻止默認事件,解決火狐的bug
        };};</script>

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

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

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

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

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

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

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; // 阻止默認事件,解決火狐的bug
        };};

?

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

那么很簡單, 我們只要合并這次與上一次的代碼就可以了,兼容嘛 做個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 下文字就不會被選中 其實就是文字或圖片得不到事件} 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; // 阻止默認事件,解決火狐的bug
                };};</script>

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

轉(zhuǎn)載于:https://www.cnblogs.com/IcemanZB/p/4228009.html

總結(jié)

以上是生活随笔為你收集整理的Javascript 拖拽的一些高级的应用——逐行分析代码,让你轻松了解拖拽的原理...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。