jQuery中頁面返回頂部的方法總結

来源:https://www.cnblogs.com/good10000/archive/2019/03/24/10588531.html
-Advertisement-
Play Games

當頁面過長時,通常會在頁面下方有一個返回頂部的button,總結一下,大概三種實現方法,下麵說下各方法及優缺點。 方法一 錨點定位 ? 1 <a href="#" class="top" id="top">返回頂部</a> ? 1 <a href="#" class="top" id="top">返 ...


當頁面過長時,通常會在頁面下方有一個返回頂部的button,總結一下,大概三種實現方法,下麵說下各方法及優缺點。

方法一 錨點定位

?
1 <a href="#" class="top" id="top">返回頂部</a>

這種方法設置方便,但缺點是會刷新頁面(我是在同事的樂視手機上發現的)。

方法二 window.scrollTo(x,y)

?
1 <a href="javascript:scrollTo(0,0)" class="top" id="top">返回頂部</a>

這種方法也很方便,並且不會刷新頁面,缺點是沒有滾動效果。

scrollTo接收的參數用來定位視口左上角在整個滾動內容區域的坐標,比如我設置scrollTo(100,100),就是讓滾動內容的坐標(100,100)的點處在視口的左上角。

方法三 jQuery插件設置帶有動畫效果的滾動

原生方法

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 /* html部分 */ <body> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <a href="javascript:;" class="top" id="top">返回頂部</a> </body> <style> /* css部分 */ div {   height: 150px; } div:nth-child(odd) {    padding: 0px 0px 0px 5px; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; border-left: 3px solid rgb(108, 226, 108); line-height: 20px; width: 640px; clear: both; outline: 0px !important; border-radius: 0px !important; border-top: 0px !important; border-right: 0px !important; border-bottom: 0px !important; border-image: initial !important; bottom: auto !important; float: none !important; height: auto !important; left: auto !important; overflow: visible !important; position: static !important; right: auto !important; top: auto !important; vertical-align: baseline !important; box-sizing: content-box !important; font-family: Consolas, "Bitstream Vera Sans Mono", "Courier New", Courier, monospace !important; min-height: auto !important; color: gray !important;">#8ae238; } div:nth-child(even) {    padding: 0px 0px 0px 5px; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; border-left: 3px solid rgb(108, 226, 108); line-height: 20px; width: 640px; clear: both; outline: 0px !important; border-radius: 0px !important; border-top: 0px !important; border-right: 0px !important; border-bottom: 0px !important; border-image: initial !important; bottom: auto !important; float: none !important; height: auto !important; left: auto !important; overflow: visible !important; position: static !important; right: auto !important; top: auto !important; vertical-align: baseline !important; box-sizing: content-box !important; font-family: Consolas, "Bitstream Vera Sans Mono", "Courier New", Courier, monospace !important; min-height: auto !important; color: gray !important;">#66d9ef; } .top {   position: fixed;   right: 50px;   bottom: 50px;   display: block;   width: 50px;   height: 50px;   font-size: 20px;      display: none; } </style> <script> /* js代碼 */   var topBtn = document.getElementById('top');   // 獲取視窗高度   var winHeight = document.documentElement.clientHeight;   window.onscroll = function () {     // 獲取頁面向上滾動距離,chrome瀏覽器識別document.body.scrollTop,而火狐識別document.documentElement.scrollTop,這裡做了相容處理     var toTop = document.documentElement.scrollTop || document.body.scrollTop;     // 如果滾動超過一屏,返回頂部按鈕出現,反之隱藏     if(toTop>=winHeight){       topBtn.style.display = 'block';     }else {       topBtn.style.display = 'none';     }   }   topBtn.onclick=function () {     var timer = setInterval(function () {       var toTop = document.documentElement.scrollTop || document.body.scrollTop;       // 判斷是否到達頂部,到達頂部停止滾動,沒到達頂部繼續滾動       if(toTop == 0){         clearInterval(timer);       }else {         // 設置滾動速度         var speed = Math.ceil(toTop/5);         // 頁面向上滾動         document.documentElement.scrollTop=document.body.scrollTop=toTop-speed;       }     },50);   } </script>

大概的思路就是:

為window綁定scroll事件,監聽頁面滾動距離,當超過一屏高度時,顯示返回頂部的按鈕

為按鈕綁定點擊事件,返回頂部的方法就是獲取頁面滾動的距離,然後計算步長,這裡採用滾動距離除以5的方式,滾動速度由快到慢。這裡使用js定時器控制滾動的頻率,建議設置較小一點的值,如果時間間隔過大會有‘跳幀'的感覺。
這種方法優點是有了動畫效果,只是實現起來比較麻煩,下麵介紹一下jQuery方法。

jQuery特效方法

jQuery方法只是在js代碼部分不同,具體代碼如下

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 <script> /* js代碼 */ $(window).on('scroll', function () {   // 判斷顯示還是隱藏按鈕   if($(this).scrollTop()>=$(this).height()){     $('#top').fadeIn('slow');   }else {     $('#top').fadeOut('slow');   } }); $('#top').on('click',function () {   // 設置滾動動畫,這裡註意使用的是$('body')不是$(window)   $('body').animate({scrollTop:'0'},500); }); </script>

jQuery方法的優點是方便,而且動畫效果比較流暢。

這裡需要註意設置animate方法時使用的是jQuery封裝的body對象而不是window對象,因為我們是要設置body的scrollTop屬性。

總結

三個方法各有優劣,不過總體來講,jQuery的方法更適合大多數場景。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文介紹了Canvas引入跨域的圖片導致toDataURL()報錯的問題的解決,分享給大家,具體如下: 【場景】 用戶打開網頁,則請求騰訊COS(圖片伺服器)上的圖片js代碼。使用canvas繪圖。 然後,用戶可以重新選擇圖片、裁剪、上傳。 【問題】 圖片首次載入,選擇新圖片後裁剪、繪製都沒有問題。 ...
  • 以下為你簡略介紹javaScript語法中創建對象的內容。 主要包括:字面量模式創建、調用系統構造函數創建、工廠模式創建、自定義構造函數創建、原型模式創建共五種。 ...
  • 有一天我們的UI設計師找到我說,要把頁面中我自己用程式寫的動畫,換成他們給的json動畫,原因是有的動畫很複雜,自己寫起來達不到他們的預期效果(寫到這裡我突然想到一個問題,這麼複雜的動畫為什麼不使用gif。。。。坐我對面的安卓開發小哥答因為gif播放的時候可能質量不高不流暢,好吧我信了) 我:??? ...
  • 在理解javascript的this之前,首先先瞭解一下作用域。 作用域分為兩種: 詞法作用域和動態作用域的區別是:詞法作用域是在寫代碼或定義時確定的;動態作用域是在運行時確定的。 this的綁定規則 this是在調用時被綁定,取決於函數的調用位置。由此可以知道,一般情況下(非嚴格模式下),this ...
  • 示例代碼托管在: "http://www.github.com/dashnowords/blogs" 博客園地址: "《大史住在大前端》原創博文目錄" 華為雲社區地址: "【你要的前端打怪升級指南】" [TOC] 一. 任務說明 使用原生 繪製散點圖。(截圖以及數據來自於百度Echarts官方示例庫 ...
  • 一、函數補充 1.1 arguments類數組對象 arguments 是一個對應於傳遞給函數的參數的類數組對象。 在函數中,使用特殊對象 arguments,開發者無需明確指出參數名,就能訪問它們。 在其它編程語言中,比如java:如果一個函數被定義過兩次,每次參數個數都不同。相當於定義了兩個不同 ...
  • jQuery實現輪播圖時出現ready方法外無法調用方法(函數) 遇到的問題: 解決ready()方法外調用方法(函數)問題(修改紅色代碼即可): 方法一: 方法二: ...
  • 我們上網經常會遇到第一次需要登錄而之後不用再登錄的網站的情況,其實是運用了Cookie 存儲 web 頁面的用戶信息,Cookie 以名/值對形式存儲,當瀏覽器從伺服器上請求 web 頁面時, 屬於該頁面的 cookie 會被添加到該請求中。服務端通過這種方式來獲取用戶的信息l。 今天的這個效果:第 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...