Detect if element has stopped momentum scrolling?

前端 未结 3 1367
有刺的猬
有刺的猬 2021-01-12 04:05

Is it possibile to detect if an element has stopped scrolling in Mobile Safari via Javascript?

I have an element that has momentum scrolling by using -webkit-o

相关标签:
3条回答
  • 2021-01-12 04:24

    You can calculate a swipe velocity and try to figure out if momentum scroll will occur based on some threshold value. I've done some testing and about 0.25 pixels/ms seems to be a good value.

    Note: Sometimes momentum scrolling will occur for lower velocities too. The lowest velocity to cause momentum scrolling that I recorded was 0.13 (with very short delta time) so if you need a 100% perfect solution, keep on looking.

    The example code also detects and deals with overscrolling.

    Using JQuery;

    var scrollWrapper = $('#myWrapper');
    var starTime, startScroll, waitForScrollEvent;
    scrollWrapper.bind('touchstart', function() {
       waitForScrollEvent = false;
    });
    
    scrollWrapper.bind('touchmove', function() { 
      startTime = new Date().getTime(); startScroll = scrollWrapper.scrollTop();
    });
    
    scrollWrapper.bind('touchend', function() {
      var deltaTime = new Date().getTime() - startTime;
      var deltaScroll = Math.abs(startScroll - scrollWrapper.scrollTop());
      if (deltaScroll/deltaTime>0.25 
            || scrollWrapper.scrollTop()<0 
            || scrollWrapper.scrollTop()>scrollWrapper.height()) {
        // will cause momentum scroll, wait for 'scroll' event
        waitForScrollEvent = true;
      }
      else {
        onScrollCompleted(); // assume no momentum scroll was initiated
      }
      startTime = 0;
    });
    
    scrollWrapper.bind('scroll', function() {
      if (waitForScrollEvent) {
        onScrollCompleted();
      }
    });
    
    0 讨论(0)
  • 2021-01-12 04:25

    You could also add a function that recursivly calls itself until the scrolling has stopped within the element and then call futher function from there.

    isScrolling() {
      var scrollStart = <element>.scrollTop;
      setTimeout(function() {
        var scrollPos = <element>.scrollTop;
        if (scrollStart !== scrollPos) {
          this.isScrolling()
        } else {
          // Scrolling has stopped
        }
      }, 100)
    }
    
    0 讨论(0)
  • 2021-01-12 04:27

    In my case this worked perfectly:

    var timer;
    $(scrollWrapper).on('scroll',function(e){
        if(timer){
            clearTimeout(timer);
        }
        timer = setTimeout(function(){
           $(this).trigger('scrollFinished');
        }, 55)
    })
    
    
    
     $(scrollWrapper).on('scrollFinished',function(){
             // will be called when momentum scroll is finished
       })
    

    Publish 'scrollfinished' event when scroll has stopped.

    0 讨论(0)
提交回复
热议问题