怎么判断滚动条滚动方向?【附demo】

问题描述:
怎么判断浏览器滚动条滚动方向?就是上下和左右滚动。

//获取浏览器scroll
function scroll() {
        if (window.pageYOffset != null){
        // 支持IE9 +
          return{
                    left:window.pageXOffset,
                    top:window.pageYOffset
                }
            }else if (document.compatMode == 'CSS1Compat'){
        return{
                        left:document.documentElement.scrollLeft,
                        top:document.documentElement.scrollTop
                }
                }
                return{
                    left:document.body.scrollLeft,
                    top:document.body.scrollTop
                }
            }

        window.onscroll = function(){
                var sLeft = scroll().left;
                var sTop = scroll().top;
                console.log('sLeft:' + sLeft);
                console.log('sTop:' + sTop);
    // if(){
    //  console.log('上下滚动')  
    //  }else{
    //    console.log('左右滚动')  
    //  }
            }

demo:看控制台打印出来的数值
codepen

阅读 12.1k
3 个回答

记得昨天在群里有人就问的这个问题。。。用闭包可以实现,关键是缓存好上次滑动时候的top和Left然后进行比较。

        function scroll() {
            if (window.pageYOffset != null) {
                // 支持IE9 +
                return {
                    left: window.pageXOffset,
                    top: window.pageYOffset
                }
            } else if (document.compatMode == 'CSS1Compat') {
                return {
                    left: document.documentElement.scrollLeft,
                    top: document.documentElement.scrollTop
                }
            }
            return {
                left: document.body.scrollLeft,
                top: document.body.scrollTop
            }
        }

        window.onscroll = (function () {
            var sLeft = scroll().left;
            var sTop = scroll().top;

            return function () {

                if (sTop != scroll().top) {
                    console.log('上下滚动')
                    sTop = scroll().top;
                }
                if (sLeft != scroll().left) {
                    //   console.log(sTop);
                    console.log('左右滚动')
                    sLeft = scroll().left;
                }
            }

        })();

略麻烦。

  • 首先获得开始滚动时滚动条的x ,y坐标

  • 然后在滚动条发生变化时对之前保存的坐标进行比较。

  • 参考

document.body.scrollTop
document.body.scrollLeft
window.onscroll
新手上路,请多包涵

写这么复杂还是只能判断 上下 或者 左右? 要是想知道是上还是下呢?

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏