JS實現回到頁面頂部動畫效果的簡單實例
來源:易賢網 閱讀:1411 次 日期:2016-06-23 16:18:30
溫馨提示:易賢網小編為您整理了“JS實現回到頁面頂部動畫效果的簡單實例”,方便廣大網友查閱!

最近在模仿各大網站寫頁面樣式和交互,發(fā)現好多都有回到頂部的需要,所以寫了一下js,記錄下來。

發(fā)現還可以添加從快到慢的動畫效果和隨時下拉滾動條停止?jié)L動的功能, 參考了imooc上相關課程,最終實現JS代碼如下:

//頁面加載后觸發(fā)

window.onload = function(){

  var btn = document.getElementById('btn');

  var timer = null;

  var isTop = true;

  //獲取頁面可視區(qū)高度

  var clientHeight = document.documentElement.clientHeight;

  //滾動條滾動時觸發(fā)

  window.onscroll = function() {

  //顯示回到頂部按鈕

    var osTop = document.documentElement.scrollTop || document.body.scrollTop;

    if (osTop >= clientHeight) {

      btn.style.display = "block";

    } else {

      btn.style.display = "none";

    };

  //回到頂部過程中用戶滾動滾動條,停止定時器

    if (!isTop) {

      clearInterval(timer);

    };

    isTop = false;

  };

  btn.onclick = function() {

    //設置定時器

    timer = setInterval(function(){

      //獲取滾動條距離頂部高度

      var osTop = document.documentElement.scrollTop || document.body.scrollTop;

      var ispeed = Math.floor(-osTop / 7);

      document.documentElement.scrollTop = document.body.scrollTop = osTop+ispeed;

      //到達頂部,清除定時器

      if (osTop == 0) {

        clearInterval(timer);

      };

      isTop = true;

    },30);

  };

};

以上這篇JS實現回到頁面頂部動畫效果的簡單實例就是小編分享給大家的全部內容了,希望能給大家一個參考

更多信息請查看網絡編程

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網