欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript 拖拽雛形中的一些問題(逐行分析代碼,讓你輕松了拖拽的原理)

 更新時(shí)間:2015年01月23日 16:55:41   作者:孫悟飯  
這篇文章主要介紹了Javascript 拖拽雛形中的一些問題(逐行分析代碼,讓你輕松了拖拽的原理),需要的朋友可以參考下

今天我們就來解決上一次拖拽雛形中的一些問題。下面看看有哪些問題?

附上上期的Javascript代碼,方便大家查看問題。

<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;

     oDiv.onmousemove = function(ev) {
      var oEvent = ev || event;
      oDiv.style.left = oEvent.clientX - disX+'px'; 
      oDiv.style.top = oEvent.clientY - disY+'px';
     };
     oDiv.onmouseup = function() {
      oDiv.onmousemove = null;
      oDiv.onmouseup = null;
     };

    };

   };
  </script>

1. 現(xiàn)在的這個(gè)拖拽如果我鼠標(biāo)移動的快點(diǎn),你會發(fā)現(xiàn)這個(gè)鼠標(biāo)從這個(gè)div出來了,這個(gè)時(shí)候div不會跟著鼠標(biāo)走了。

那為什么會出現(xiàn)這個(gè)問題呢?

原因其實(shí)很簡單,mousemove的事件我們是給div加的,所以鼠標(biāo)一旦脫離了這個(gè)div,那么這個(gè)時(shí)候mousemove已經(jīng)不觸發(fā)了。

解決方案: 事件加載document 上,因?yàn)槟闶髽?biāo)無論如何都還在頁面里面,怎么樣都會觸發(fā)mousemove 這樣移動的在快也沒問題。

那么我們相應(yīng)的修改下代碼。

<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;
    // 事件加載document 上
     document.onmousemove = function(ev) {
      var oEvent = ev || event;
      oDiv.style.left = oEvent.clientX - disX+'px';
      oDiv.style.top = oEvent.clientY - disY+'px';
     };
     oDiv.onmouseup = function() {
      document.onmousemove = null;
      oDiv.onmouseup = null; 
     };

    };

   };
  </script>

那么這個(gè)問題就可以解決了。

2. 我們看看現(xiàn)在還有什么問題,雖然拖的快的問題解決了,但是當(dāng)我把鼠標(biāo)移動到這個(gè)位置

現(xiàn)在可以明顯看到鼠標(biāo)不在div上,如果這個(gè)時(shí)候抬起鼠標(biāo),你可以看到回來之后它還會動。 這就又是一個(gè)bug!

其實(shí)這個(gè)問題和上面的是一樣的。所以呢解決起來也很簡單我們把mouseup也加到document上,我們來試一下看看

document.onmouseup = function() { 
      document.onmousemove = null; 
      document.onmouseup = null; 
     };

這樣 現(xiàn)在如果在移動到剛才的那個(gè)位置,就不會在出現(xiàn)之前的bug了,并且移動的快也沒有任何的問題。一切都很正常。

3. 我們看看瀏覽器兼容的問題

其實(shí)在低版本的火狐瀏覽器中有這樣一個(gè)問題
。怎么出現(xiàn)的呢,當(dāng)你第一次拖的時(shí)候是對的,在拖一次的時(shí)候按住在移動,你會發(fā)現(xiàn)會有個(gè)這個(gè)影子在后面。這個(gè)是怎么回事呢?

實(shí)際上來說我們現(xiàn)在拖動的是一個(gè)空的div火狐是有bug的,那么如果在div中加點(diǎn)內(nèi)容呢

你會發(fā)現(xiàn)現(xiàn)在又沒有問題了。

所以火狐的bug就只有在空div中出現(xiàn)的。

解決方案:

其實(shí)很簡單,我們就只要阻止瀏覽器默認(rèn)事件就可以了 return false; 在onmousedown中。 為什么要加在onmousedown中呢?

大家可以想一下,拖拽是從哪個(gè)事件開始的,是從onmousedown開始的吧,當(dāng)鼠標(biāo)按下的時(shí)候拖拽就開始了。所以要加載onmousedown中。

實(shí)際上就是加了一句return false; 把火狐的bug屏蔽掉了。

這樣不管怎么拖就沒有問題了。

附上代碼:

<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;
     // 事件加載document 上
     document.onmousemove = function(ev) {
      var oEvent = ev || event;
      oDiv.style.left = oEvent.clientX - disX+'px';
      oDiv.style.top = oEvent.clientY - disY+'px';
     };
     document.onmouseup = function() {
      document.onmousemove = null;
      document.onmouseup = null;
     };

     return false;

    };

   };
  </script>

現(xiàn)在程序是完整了,但是在用戶體驗(yàn)上還有一些問題。

比如說用戶可能會把這個(gè)div拖出瀏覽器外面,那怎么解決呢?

那我們就在加個(gè)判斷唄。 這個(gè)很簡單吧,如果從左邊出去了

,那就直接等于0,他就從左邊出不去了。那么上邊也是一樣的。

那么怎么防止不能從右邊出去?? 畫個(gè)圖就清楚了。 其實(shí)我們只要把頁面的可視取的寬度減掉div的寬度就能算出來了。

那這個(gè)就是所謂的最大值,判斷一下如果移動的距離超過了這個(gè)最大值就等于這個(gè)最大值即可。那么下邊是一樣的。

附上完整代碼:

<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;

          document.onmousemove = function(ev) {
            var oEvent = ev || event;
            // 存儲div當(dāng)前的位置
            var oDivLeft = oEvent.clientX - disX;
            var oDivTop = oEvent.clientY - disY;


            // 從左邊拖出去了
            if (oDivLeft < 0) {
              oDivLeft = 0;
            } else if (oDivLeft > document.documentElement.clientWidth - oDiv.offsetWidth) {
              oDivLeft = document.documentElement.clientWidth - oDiv.offsetWidth;
            }

            if (oDivTop < 0) {
              oDivTop = 0;
            } else if (oDivTop > document.documentElement.clientHeight - oDiv.offsetHeight) {
              oDivTop = document.documentElement.clientHeight - oDiv.offsetHeight;
            }

            oDiv.style.left = oDivLeft + 'px';
            oDiv.style.top = oDivTop + 'px';
          };

          document.onmouseup = function() {
            document.onmousemove = null;
            document.onmouseup = null;
          };
          return false; // 阻止默認(rèn)事件,解決火狐的bug
        };
      };
    </script>

那么現(xiàn)在這個(gè)拖拽就比較完整啦。O(∩_∩)O

相關(guān)文章

  • 全屏滾動插件fullPage.js使用實(shí)例解析

    全屏滾動插件fullPage.js使用實(shí)例解析

    這篇文章主要為大家解析了全屏滾動插件fullPage.js使用實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • 微信小程序保持session會話的方法

    微信小程序保持session會話的方法

    這篇文章主要介紹了微信小程序保持session會話的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • 純JS代碼實(shí)現(xiàn)隔行變色鼠標(biāo)移入高亮

    純JS代碼實(shí)現(xiàn)隔行變色鼠標(biāo)移入高亮

    這篇文章主要介紹了純JS代碼實(shí)現(xiàn)隔行變色鼠標(biāo)移入高亮的相關(guān)資料,非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2016-11-11
  • javascript 不用reverse實(shí)現(xiàn)字符串反轉(zhuǎn)的代碼

    javascript 不用reverse實(shí)現(xiàn)字符串反轉(zhuǎn)的代碼

    javascript 不用reverse實(shí)現(xiàn)字符串反轉(zhuǎn)的代碼,需要的朋友可以參考下。
    2010-03-03
  • 在JavaScript中使用timer示例

    在JavaScript中使用timer示例

    這篇文章主要介紹了在JavaScript中如何使用timer,并給出各種測試case的例子,需要的朋友可以參考下
    2014-05-05
  • 一文搞懂?parseInt()函數(shù)異常行為

    一文搞懂?parseInt()函數(shù)異常行為

    這篇文章主要為大家介紹了一文搞懂?parseInt()函數(shù)異常行為示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • 使用純JS代碼判斷字符串中有多少漢字的實(shí)現(xiàn)方法(超簡單實(shí)用)

    使用純JS代碼判斷字符串中有多少漢字的實(shí)現(xiàn)方法(超簡單實(shí)用)

    這篇文章主要給大家介紹了js判斷字符串中有多少漢字的實(shí)現(xiàn)方法然后給大家分享了使用JS判斷輸入字符串長度的兩種方法,非常不錯具有參考借鑒價(jià)值,感興趣的朋友一起看看吧
    2016-11-11
  • 微信小程序自定義導(dǎo)航欄實(shí)例代碼

    微信小程序自定義導(dǎo)航欄實(shí)例代碼

    這篇文章主要給大家介紹了關(guān)于微信小程序自定義導(dǎo)航欄的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用微信小程序具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • js 立即調(diào)用的函數(shù)表達(dá)式如何寫

    js 立即調(diào)用的函數(shù)表達(dá)式如何寫

    如果不需要顯示調(diào)用函數(shù), 讓這個(gè)函數(shù)在定義的時(shí)候就執(zhí)行的話, 該如何寫才可以呢,下面為大家介紹下具體的實(shí)現(xiàn)步驟,喜歡的朋友可以了解下
    2014-01-01
  • javascript圖像處理—仿射變換深度理解

    javascript圖像處理—仿射變換深度理解

    上一篇文章,我們講解了圖像金字塔,這篇文章我們來了解仿射變換,仿射?任何仿射變換都可以轉(zhuǎn)換成,乘以一個(gè)矩陣(線性變化),再加上一個(gè)向量(平移變化),接下來詳細(xì)介紹,感興趣的朋友可以了解下
    2013-01-01

最新評論