document body scrollTop的值总为零的解决办法

有一个功能需要判断返回顶部按钮是否显示。

JS代码如下:

 var sTop = document.body.scrollTop;
    if(sTop>100){
        document.getElementById("sm_top").style.display="block";
    }else{
        document.getElementById("sm_top").style.display="none";
    }

但是发现document.body.scrollTop一直是0。

查资料发现是DTD的问题。

页面指定了DTD,即指定了DOCTYPE时,使用document.documentElement。

页面没有DTD,即没指定DOCTYPE时,使用document.body。

IE和Firefox都是如此。

而我的页面加了,所以如下即可。

/*判断回到顶部按钮显示与否*/
     window.onscroll=function(){
        var sTop = document.documentElement.scrollTop;
    if(sTop>100){
        document.getElementById("sm_top").style.display="block";
    }else{
        document.getElementById("sm_top").style.display="none";
    }
    }

为什么会出现上面的错误,下面代码会导致这样的问题

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

页面此时才正常.

原来是这行东西造成IE无法获取document.body.scrolltop!

把顶部这两行删掉将可以了.但是为什么会这样呢?

google一下,发现改成:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

就可以了,但页面稍有变化,感觉不爽,于是又在google里找,终于解决

var scrollPos; 
if (typeof window.pageYOffset != 'undefined') 
{ 
   scrollPos = window.pageYOffset; 
} 
else if (typeof document.compatMode != 'undefined' &&    document.compatMode != 'BackCompat') 
{ 
   scrollPos = document.documentElement.scrollTop; 
} 
else if (typeof document.body != 'undefined') 
{ 
   scrollPos = document.body.scrollTop; 
} 
alert(scrollPos);

document.body.scrollTop
要改成
document.documentElement.scrollTop

上面的方法虽然能解决问题,但是有时候当我们再次进入是document.documentElement.scrollTop不管用了但是document.body.scrollTop 又管用了,怎么办,最好两个都写
如下:

var roll = document.body.scrollTop || document.documentElement.scrollTop

这是问题就完美解决了

本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:http://www.cnblogs.com/starof/p/5238654.html有问题欢迎与我讨论,共同进步。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值