国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

history保存列表頁ajax請求的狀態使用示例詳解

瀏覽:193日期:2022-06-12 08:16:33
目錄
  • 問題
    • 優化前代碼
  • history
    • history.pushState()
    • window.onpopstate
  • 問題2

    問題

    最近碰到兩個問題:

    • 從首頁進入列表頁之后,點擊下一頁的時候,使用ajax請求更新數據, 然后點擊瀏覽器“后退”按鈕就直接返回到首頁,實際這里想要的效果是返回列表頁上一頁。
    • 在列表頁分頁為2的頁面進入詳情頁,然后點擊“后退”按鈕,返回的事列表頁分頁為1的頁面。沒法記住之前分頁狀態。

    優化前代碼

    代碼如下,在頁數變化的時候,去異步請求數據,渲染頁面。

    const currentChange = (currentPage) => {
        ajax(`請求地址/${currentPage}`)
        .then(renderPage)
    }
    

    history

    經過幾番搜索,發現可以用History 接口來實現我們想要功能。

    history.pushState()

    按指定的名稱和URL(如果提供該參數)將數據push進會話歷史棧,數據被DOM進行不透明處理;你可以指定任何可以被序列化的javascript對象。具體描述可以參考文檔

    通過history.pushState(state, title, url)可以修改會話歷史棧,把我們需要保存的數據存到state中,這里我們存入一個對象,屬性為當前頁數;title一般沒什么用,這里傳入null;url會修改當前歷史紀錄的地址,瀏覽器在調用pushState()方法后不會去加載這個URL

    假設當前currentPage為1,當前url為www.example.com/search/index

    ...
    const pushState = () => {
        const url = `/search/index/${currentPage}`
        history.push({
    page: currentPage
        }, null, url)
    }
    const currentChange = (currentPage) => {
        ajax(`請求地址/${currentPage}`)
        .then(res =>{
    pushState(currentPage)
    renderPage()
        })
    }
    ...
    

    現在代碼執行順序是:頁數改變 => ajax請求 => pushState => renderPage()

    在pushState之后當前url變成www.example.com/search/index/1

    window.onpopstate

    現在我們通過history.pushState()方法把狀態存入歷史會話中了,接下來就要監聽window.onpopstate事件

    參考mdn文檔window.onpopstate

    每當處于激活狀態的歷史記錄條目發生變化時,popstate事件就會在對應window對象上觸發.

    調用history.pushState()或者history.replaceState()不會觸發popstate事件. popstate事件只會在瀏覽器某些行為下觸發, 比如點擊后退、前進按鈕(或者在JavaScript中調用history.back()、history.forward()、history.go()方法).

    接下來監聽這個事件

    window.addEventListener("popstate", (event) => {
    	if(event.state !== null){
    	    page = event.state.page
    	    changeCurrentPage(page) // 修改當前頁數
    	}
    })
    

    當popstate觸發時,會修改當前頁數,然后觸發之前定義的currentChange方法,更新數據,渲染頁面。

    問題2

    到此為止,問題1就解決了。

    接下來要解決問題二:從詳情頁返回列表頁,記住之前的狀態
    這里我用url來記錄狀態,之前pushState推入的url就派上用場了。 只要把進入頁面首次請求的地址改成當前url就可以了

    假設之前push的url為www.example.com/search/index/5,從詳情頁返回之后url還會顯示www.example.com/search/index/5

    mounted () {
        ajax(location.href)
    }
    

    這樣就完成了。 當然如果你的狀態比較復雜,可以把數據存入本地Storage,添加一些判斷即可

    以上就是history保存列表頁ajax請求的狀態使用示例詳解的詳細內容,更多關于history保存列表頁ajax請求狀態的資料請關注其它相關文章!

    標簽: Ajax
    主站蜘蛛池模板: 亚洲国产一区在线 | 国产精品yjizz视频网一二区 | 国产成人精品三级在线 | 成年男人午夜片免费观看 | 精品日韩欧美一区二区三区在线播放 | 国产成人精品999在线观看 | 美女国产福利视频 | 亚洲久草视频 | 亚洲成a人不卡在线观看 | 免费一级毛片在线播放不收费 | 1024国产欧美日韩精品 | 成人午夜网 | 美女张腿男人桶免费视频 | 亚洲永久中文字幕在线 | 亚洲aⅴ在线 | 国产99久久 | 国产精品亚洲片在线观看不卡 | 日韩午夜视频在线观看 | 久久久久欧美情爱精品 | 多人伦精品一区二区三区视频 | 精品国产免费第一区二区 | 久久亚洲精品国产精品777777 | 一级毛片免费观看 | 全免费毛片在线播放 | 综合色久 | 久久久亚洲精品蜜桃臀 | 青青自拍| 成人黄色毛片 | 亚洲精品欧洲久久婷婷99 | 亚洲视频国产 | 欧美国产成人一区二区三区 | 亚洲依依成人综合在线网址 | 宫女淫春 | 国产不卡在线观看视频 | 一区二区在线播放福利视频 | 伊人色综合久久成人 | 欧美成人毛片在线视频 | 色偷偷亚洲女人天堂观看欧 | 国产真人毛片一级视频 | 国产精品一区二区免费 | 九九re6精品视频在线观看 |