欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS實現(xiàn)刷新網(wǎng)頁后之前瀏覽位置保持不變示例詳解

 更新時間:2022年08月11日 09:27:41   作者:camellia  
這篇文章主要為大家介紹了JS實現(xiàn)刷新網(wǎng)頁后之前瀏覽位置保持不變示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

正文

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

我重新加載網(wǎng)頁,刷新之后,滾動條依然定位在我剛剛瀏覽的位置,這個小功能感覺還不錯,挺方便的。

具體是怎么實現(xiàn)的呢,去網(wǎng)上大概查了一下。

這個是使用滾動條屬性scrollTop來實現(xiàn)的。

基本實現(xiàn)流程:滾動條移動的時候,將滾動條實時的位置存入Cookie或者localstorage中,但是一些老舊的瀏覽器版本對localstorage支持不是特別友好。

如果你想使用localstorage來實現(xiàn),請參照《VUE自學(xué)筆記之使用localstorage和sessionstorage實現(xiàn)登錄

我這里使用的是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存取各封裝成函數(shù)

這個將cookie的存取各封裝成了一個函數(shù),調(diào)用更靈活。

window.onscroll = function() {
        var scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;
        SetCookie("a", scrollTop);
    }
    window.onload = function () {
        document.body.scrollTop = GetCookie("a");//頁面加載時設(shè)置scrolltop高度
    }
    /**
     * @name: 設(shè)置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實現(xiàn)刷新網(wǎng)頁后之前瀏覽位置保持不變示例詳解的詳細(xì)內(nèi)容,更多關(guān)于JS刷新網(wǎng)頁瀏覽位置保持的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • JS前端面試手寫apply和bind實例

    JS前端面試手寫apply和bind實例

    這篇文章主要為大家介紹了JS前端面試手寫apply和bind實例的輕松實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 微信小程序 圖片加載(本地,網(wǎng)路)實例詳解

    微信小程序 圖片加載(本地,網(wǎng)路)實例詳解

    這篇文章主要介紹了微信小程序 圖片加載(本地,網(wǎng)路)實例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • uniApp學(xué)習(xí)之熱門搜索,搜索數(shù)據(jù)頁面緩存實例

    uniApp學(xué)習(xí)之熱門搜索,搜索數(shù)據(jù)頁面緩存實例

    這篇文章主要介紹了uniApp學(xué)習(xí)之熱門搜索,搜索數(shù)據(jù)頁面緩存實例,需要的朋友可以參考下
    2023-10-10
  • 使用JavaScript破解web

    使用JavaScript破解web

    今天小編就為大家分享一篇關(guān)于使用JavaScript破解web的文章,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-09-09
  • JS前端錯誤監(jiān)控捕獲以及上報方法詳解

    JS前端錯誤監(jiān)控捕獲以及上報方法詳解

    這篇文章主要為大家介紹了前端錯誤監(jiān)控捕獲以及上報方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • JavaScript函數(shù)柯里化

    JavaScript函數(shù)柯里化

    這篇文章主要介紹了JavaScript函數(shù)柯里化,柯里化即Currying是把接受多個參數(shù)的函數(shù)變換成接受一個單一參數(shù)函數(shù),并且返回接受余下的參數(shù)且返回結(jié)果的新函數(shù)的技術(shù),下面文章詳細(xì)內(nèi)容,需要的朋友可以參考一下
    2021-11-11
  • 前端JS實現(xiàn)太極圖案圖文示例

    前端JS實現(xiàn)太極圖案圖文示例

    這篇文章主要為大家介紹了前端JS實現(xiàn)太極圖案圖文示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • 微信小程序商品到詳情的實現(xiàn)

    微信小程序商品到詳情的實現(xiàn)

    這篇文章主要介紹了微信小程序商品到詳情的實現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • JavaScript對象(詳細(xì))

    JavaScript對象(詳細(xì))

    這篇文章主要介紹了Java中的Script對象的相關(guān)資料,需要的朋友可以參考下文章里內(nèi)容
    2021-08-08
  • 微信小程序 實現(xiàn)點擊添加移除class

    微信小程序 實現(xiàn)點擊添加移除class

    這篇文章主要介紹了 微信小程序 實現(xiàn)點擊添加移除class的相關(guān)資料,需要的朋友可以參考下
    2017-06-06

最新評論