具有彈性的點選返回網頁頂部程式碼

admin發表於2017-02-11
當一個網頁較長時,如果同網頁底部拖動滾動條回到頂部算是一個不大不小的麻煩事情,尤其是操作比較頻繁的情況下更是如此,下面就介紹一個點選能夠返回網頁頂部的功能,並且此功能具有彈性效果。

程式碼例項如下:

[HTML] 純文字檢視 複製程式碼
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style>
body {
  height:3600px;
}
#goTopBtn {
  position:fixed;
  text-align:center;
  line-height:30px;
  width:30px;
  bottom: 5px;
  height:33px;
  font-size:12px;
  cursor:pointer;
  right:0px;
  _position:absolute;
  _right:auto
}
</style>
<script type="text/javascript"> 
function goTopEx() {
  var obj = document.getElementById("goTopBtn");

  function getScrollTop() {
    return document.documentElement.scrollTop + document.body.scrollTop;
  }

  function setScrollTop(value) {
    if (document.documentElement.scrollTop) {
      document.documentElement.scrollTop = value;
    } else {
      document.body.scrollTop = value;
    }
  }

  window.onscroll = function() {
    getScrollTop() > 0 ? obj.style.display = "" : obj.style.display = "none";
  }

  obj.onclick = function() {
    var goTop = setInterval(scrollMove, 10);

    function scrollMove() {
      setScrollTop(getScrollTop() / 1.1);
      if (getScrollTop() < 1) clearInterval(goTop);
    }
  }
}
</script>
</head>
<body style="text-align:center">
<div style="display: none" id="goTopBtn"><img border=0 src="img/top.png"></div>
<script type="text/javascript">
goTopEx()
</script> 
超出首屏範圍,即會出現TOP按鈕,否則自動隱藏。
</body>
</html>

以上程式碼實現了我們想要的功能,當下拉滾動條的時候能夠出現一個圖片,當地點選此圖片的時候,能夠平滑的回到網頁頂部,下面就簡單介紹一下如何實現此功能。

一.實現原理:

當下拉滾動條的時候,會將點選按鈕設定為顯示,當點選按鈕的時候通過定時器函式不斷的設定scrollTop值,當小於1的時候停止設定(這個時候已經基本返回頂部),這樣就實現了彈性返回頂部的效果。

二.程式碼註釋:

1.var obj = document.getElementById("goTopBtn"),獲取id屬性值為goTopBtn的物件。

2.function getScrollTop(){},獲取滾動條向下拖動的尺寸。

3.return document.documentElement.scrollTop + document.body.scrollTop,用來相容各主流瀏覽器。

4.function setScrollTop(value){},設定滾動的距離,裡面有相容性寫法。

5.window.onscroll = function(){},觸發滾動事件。

6.getScrollTop() > 0 ? obj.style.display = "": obj.style.display = "none",如果已經向下滾動距離大於0,那麼將點選按鈕設定為可見,否則不可見。

7.obj.onclick = function(){},為點選按鈕繫結事件處理函式。

8.var goTop = setInterval(scrollMove, 10),通過定時器函式每隔十秒呼叫一次scrollMove()函式,以此實現彈性上劃效果。

9.function scrollMove(){},用來規定上劃的規則。

10.setScrollTop(getScrollTop() / 1.1),每執行一次scrollMove()函式就設定一次新的scrollTop值。

11.if (getScrollTop() < 1) clearInterval(goTop),如果scrollTop值小於1,就停止定時器函式的執行。

相關文章