首頁 > 軟體

JS實現重新整理網頁後之前瀏覽位置保持不變範例詳解

2022-08-11 14:02:32

正文

在京東上瀏覽的時候,發現了一個比較人性化的小功能,瀏覽商品,瀏覽到一半的時候,如下圖所示:

我重新載入網頁,重新整理之後,卷軸依然定位在我剛剛瀏覽的位置,這個小功能感覺還不錯,挺方便的。

具體是怎麼實現的呢,去網上大概查了一下。

這個是使用卷軸屬性scrollTop來實現的。

基本實現流程:卷軸移動的時候,將卷軸實時的位置存入Cookie或者localstorage中,但是一些老舊的瀏覽器版本對localstorage支援不是特別友好。

如果你想使用localstorage來實現,請參照《VUE自學筆記之使用localstorage和sessionstorage實現登入

我這裡使用的是cookie來儲存。

這裡有兩個方法

方法一:這個比較集中

/**
 * @name: 控制 瀏覽器卷軸
 * @author: camellia
 * @email: guanchao_gc@qq.com
 * @date: 2022-01-10 
 */
window.onscroll = function() {
        var scrollPos;
        if (typeof window.pageYOffset != 'undefined') {
            scrollPos = window.pageYOffset;
        }
        else if (typeof document.body != 'undefined') {
            scrollPos = document.body.scrollTop;
        }
        document.cookie = "scrollTop=" + scrollPos; 
    }
    window.onload = function (){
        if (document.cookie.match(/scrollTop=([^;]+)(;|$)/) != null) {
            var arr = document.cookie.match(/scrollTop=([^;]+)(;|$)/); 
            document.body.scrollTop = parseInt(arr[1]); 
        }
    }

方法二:cookie存取各封裝成函數

這個將cookie的存取各封裝成了一個函數,呼叫更靈活。

window.onscroll = function() {
        var scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;
        SetCookie("a", scrollTop);
    }
    window.onload = function () {
        document.body.scrollTop = GetCookie("a");//頁面載入時設定scrolltop高度
    }
    /**
     * @name: 設定cookie
     * @author: camellia
     * @email: guanchao_gc@qq.com
     * @date: 2022-01-10 
     */
    function SetCookie(sName, sValue) {
        document.cookie = sName + "=" + escape(sValue) + "; ";
    }
    /**
     * @name: 讀取cookie
     * @author: camellia
     * @email: guanchao_gc@qq.com
     * @date: 2022-01-10 
     */
    function GetCookie(sName) {
        var aCookie = document.cookie.split("; ");
        for (var i = 0; i < aCookie.length; i++) {
            var aCrumb = aCookie[i].split("=");
            if (sName == aCrumb[0])
            {
                return unescape(aCrumb[1]);
            }
        }
        return 0;
    }

其實這個就是一個對cookie儲存和取值以及scrollTop賦值的一個過程,不是很難。

上邊的兩段程式碼,一般情況下,只要放到你的專案裡邊就能好用。

如果不好用,請重新檢查一下,你的專案中是否還有別的地方對scrollTop賦值。

以上就是JS實現重新整理網頁後之前瀏覽位置保持不變範例詳解的詳細內容,更多關於JS重新整理網頁瀏覽位置保持的資料請關注it145.com其它相關文章!


IT145.com E-mail:sddin#qq.com