【JavaScript】利用滾動事件window.onscroll與position:fixed寫兼容IE6的回到頂部組件

現在網上的回到頂部組件,懂不懂就一大段讓人看不懂javascript代碼,還各種不兼容。起始這個組件,完全可以自己利用javascript的滾動事件window.onscroll與position:fixed手寫。IE6的兼容性問題主要出現在position:fixed上面,如何解決已經在《【CSS】IE6中的position:fixed問題與隨滾動條滾動的效果》(點擊打開鏈接)介紹過了。

下面具體說說如何利用JavaScript中的滾動事件window.onscroll實現這個回到頂部組件。具體效果如下:

IE6:


IE8:


FireFox:


首先是HTML+CSS的佈局,在頁面的最頂部佈置一個id與name皆爲page_top的<a></a>作爲錨點,之所以要共同設置id與name一切爲了兼容。

然後就是在右下角放一個position:fixed的,內容爲↑的div,當然你想搞得炫一點可以弄成一張圖片,甚至搞成♂也可以,這個div一開始是隱藏的。

最後是一大堆沒有意義的、佔位置的<p>,沒什麼好說的。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
		<title>回到頂部</title>
		<style type="text/css">
		#top_div{
			position:fixed;
			bottom:0px;
			right:0px;
			display:none;
			/*兼容IE6的position:fixed*/
			_position: absolute;                  
			_top: expression(eval(  
			document.documentElement.scrollTop + document.documentElement.clientHeight-this.offsetHeight-  
			(parseInt(this.currentStyle.marginTop,10)||0)-  
			(parseInt(this.currentStyle.marginBottom,10)||0)));  
			_margin-bottom:0px;
			_margin_right:0px;
		}
		</style>
	</head>
	<body>
		<a id="page_top" name="page_top"></a><!--回到頂部的錨點-->
		<div id="top_div"><a href="#page_top" style="text-decoration:none">↑</a></div>
		<p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p>
		<p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p>
		<p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p>
		<p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p>
		<p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p><p>佔位置的內容</p>
	</body>
</html>

之後的腳本部分,一切很明朗了:

<script type="text/javascript">
    window.onscroll = function(){
        var t = document.documentElement.scrollTop || document.body.scrollTop;
        var top_div = document.getElementById("top_div");
        if (t >= 300) {
            top_div.style.display = "inline";
        }
        else {
            top_div.style.display = "none";
        }
    }
</script>

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章