scroll滚动事件在浏览器中无效

因为兼容性问题


scrollTop: 被卷去的头部
它就是当你滑动滚轮浏览网页的时候网页隐藏在屏幕上方的距离

怎么得到scrollTop
window.onscroll = function() { 页面滚动语句  }

1.谷歌浏览器 和没有声明 DTD :

document.body.scrollTop;  

2.火狐 和其他浏览器 (就是document.html.scrolltop的意思,只是没有document.html这样的写法而已)

  document.documentElement.scrollTop;  

ie9+ 和 最新浏览器 (都认识scroll)

  window.pageXOffset;     pageYOffset  (scrollTop)

兼容性写法:

window.onscroll = function(){
    var scrollTop = window.pageYOffset || document.documentElement.scrollTop || 
        document.body.scrollTop || 0;
    document.title = scrollTop;
    }

封装scrollTop:

<script>
//   var json = {left: 10, right: 10}  变异
//json.left   json.top
function scroll() {
    if(window.pageYOffset != null)  //  ie9+ 和其他浏览器
    {
        return {
            left: window.pageXOffset,
            top: window.pageYOffset
        }
    }
    else if(document.compatMode == "CSS1Compat")  // 声明的了 DTD
      // 检测是不是怪异模式的浏览器 -- 就是没有 声明<!DOCTYPE html>
    {
        return {
            left: document.documentElement.scrollLeft,
            top: document.documentElement.scrollTop
        }
    }
    return { //  剩下的肯定是怪异模式的
        left: document.body.scrollLeft,
        top: document.body.scrollTop
    }
}
window.onscroll = function() {
    console.log(scroll().top);
}
</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值