document.body.scrollTop返回值為0解決方案

antzone發表於2017-03-24

在應用可能會遇到這樣的情況,那就是document.body.scrollTop有時候能夠正確的返回頁面上滾的距離,有時候得到的值卻只是0,之所以出現此現象是因為存在著瀏覽器相容性問題,下面就做一下簡單介紹。

一.符合w3c標準的情況:

當在頁面的頂端新增<!DOCTYPE html>的時候會出現如下情況:

1.IE和火狐瀏覽器中,document.body.scrollTop返回值是0,document.documentElement.scrollTop則能夠返回正常值。

2.在谷歌瀏覽器中,document.body.scrollTop能夠返回正常值,而document.documentElement.scrollTop不能。

二.不符合w3c標準的情況:

也就是頁面頂端沒有<!DOCTYPE html>的時候會出現如下情況:

1.IE和火狐瀏覽器中,document.body.scrollTop能夠返回正常值,document.documentElement.scrollTop不能夠返回正常值。

2.在谷歌瀏覽器中,document.body.scrollTop能夠返回正常值,document.documentElement.scrollT也不能夠返回正常值。

最後總結:

谷歌瀏覽器是最為符合w3c標準的瀏覽器之一,但是這個地方有點反常,IE和火狐需要使用document.documentElement.scrollTop返回正常的,而谷歌瀏覽器則需要使用document.body.scrollTop,所以要進行一下相容性處理,程式碼如下:

[JavaScript] 純文字檢視 複製程式碼
document.documentElement.scrollTop || document.body.scrollTop;

程式碼例項:

[HTML] 純文字檢視 複製程式碼
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css">
body{
  height:1000px;
}
#thediv{
  position:absolute;
  top:0px;
  right:0px;
  width:50px;
  height:50px;
  background:green;
}
</style>
<script type="text/javascript">
window.onload=function(){
  window.onscroll=function () {
    var odiv=document.getElementById("thediv");
    var top=document.documentElement.scrollTop || document.body.scrollTop;
    odiv.style.top=top+"px";
  }
}
</script>
</head>
<body>
<div id="thediv"></div>
</body>
</html>

相關文章