H 5でページスクロールイベントを傍受し、スクロール方向を判断する方法

2916 ワード

H 5開発をする際には、ページのスクロールを傍受するイベントが必要になる場合があり、ページのスクロール方向によって異なる操作が行われ、通常はページが上にスクロールするか下にスクロールするかを判断しますが、どのように判断するかは、次の数十行のコードを使うだけです.
//        
function scrollEvent() {
    window.onscroll = function(e){
        scrollFunc();
        if(scrollDirection == 'down'){
            //           
        }
        else if(scrollDirection == 'up'){
            //           
        }
    }
}

var scrollAction = {x: 'undefined', y: 'undefined'}, scrollDirection;
function scrollFunc() {
    if (typeof scrollAction.x == 'undefined') {
        scrollAction.x = window.pageXOffset;
        scrollAction.y = window.pageYOffset;
    }
    var diffX = scrollAction.x - window.pageXOffset;
    var diffY = scrollAction.y - window.pageYOffset;
    if (diffX < 0) {
        // Scroll right
        scrollDirection = 'right';
    } else if (diffX > 0) {
        // Scroll left
        scrollDirection = 'left';
    } else if (diffY < 0) {
        // Scroll down
        scrollDirection = 'down';
    } else if (diffY > 0) {
        // Scroll up
        scrollDirection = 'up';
    } else {
        // First scroll event
    }
    scrollAction.x = window.pageXOffset;
    scrollAction.y = window.pageYOffset;
}