首頁  >  文章  >  web前端  >  JS在行動端實作上拉下滑的功能介紹

JS在行動端實作上拉下滑的功能介紹

巴扎黑
巴扎黑原創
2018-05-19 09:50:472559瀏覽

透過手指觸屏,利用touchstart和touchend計算前後滑動距離,判斷是上拉還是下滑。接下來透過實例程式碼跟大家介紹js行動端判斷上拉和下滑功能,有興趣的朋友一起看看吧

一、手指觸屏,利用touchstart和touchend計算前後滑動距離,判斷是上拉還是下滑。

二、js中距離:pageY、clientY、offsetY的區別:

       offsetY:相對於父節點的偏移距離。

       clientY:相對於瀏覽器,滾筒距離不算。

       pageY:相對於瀏覽器,滾輪滾動的距離算在內;本例中,用pageY,觸屏時記錄位置-startY,結束時記錄-endY,兩個相減以正負判斷是上移還是下滑。 

三、touchstart有touches屬性,touchend有changedTouches屬性,兩個屬性中分別有pageY、pageX資訊。

//滑动处理 
    var startX, startY; 
    document.addEventListener('touchstart',function (ev) { 
      startX = ev.touches[0].pageX; 
      startY = ev.touches[0].pageY; 
    }, false); 
    document.addEventListener('touchend',function (ev) { 
      var endX, endY; 
      endX = ev.changedTouches[0].pageX; 
      endY = ev.changedTouches[0].pageY; 
      var direction = GetSlideDirection(startX, startY, endX, endY); 
      switch(direction) { 
        case 0: 
            alert("无操作"); 
          break; 
        case 1: 
          // 向上 
          alert("up"); 
          break; 
        case 2: 
          // 向下 
          alert("down"); 
          break; 
 
        default: 
      } 
    }, false);

四、

function GetSlideDirection(startX, startY, endX, endY) { 
      var dy = startY - endY; 
      //var dx = endX - startX; 
      var result = 0; 
      if(dy>0) {//向上滑动 
        result=1; 
      }else if(dy<0){//向下滑动 
        result=2; 
      } 
      else 
      { 
        result=0; 
      } 
      return result; 
    }

以上是JS在行動端實作上拉下滑的功能介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn