ajax與HTML5 history pushState/replaceState實例

1、本文就是個實例展現

三點:html

  1. 我就TM想找個例子,知道如何個使用,使用語法什麼的滾粗
  2. 跟搜索引擎搞基
  3. 本身備忘

精力老是有限的,昨天一衝動,在上海浦東外環以外訂了個90米的房子,要借錢籌首付、貸款和領證什麼的。HTML5 history相關知識點啪啦啪啦講起來也是一條又臭又長的裹腳布,精氣神實在不夠用,這裏,直接一個實例。html5

2、ajax載入與瀏覽器歷史的前進與後退

衆所周知,Ajax能夠實現頁面的無刷新操做——優勢;可是,也會形成另外的問題,沒法前進與後退!曾幾什麼時候,Gmail彷佛藉助iframe搞定,現在,HTML5讓事情變得如同過家家般簡單。web

當執行Ajax操做的時候,往瀏覽器history中塞入一個地址(使用pushState)(這是無刷新的);因而,返回的時候,經過URL或其餘傳參,咱們就能夠還原到Ajax以前的模樣。ajax

本demo所展現的就是ajax的內容載入與地址欄的前進與後退,典型應用,對於熟悉相關知識點頗有幫助。api

3、demo實例

您能夠狠狠地點擊這裏:HTML5 history API與ajax分頁實例瀏覽器

demo結構大體以下:左邊導航菜單,右側詳細內容。 demo頁面大體結構搜索引擎

若是咱們想偷懶,導航直接URL地址,點擊刷新得了。但頭尾內容都是同樣的,刷新總顯得浪費。從體驗上講,點擊導航,右側Ajax局部刷新是更優的策略。spa

Ajax局部刷新小菜,稍有經驗都能輕鬆應對。如今若是提出以下需求:每次ajax刷新就若是頁面刷新同樣,能夠後退查看以前內容,怎麼破?code

個人策略以下:orm

  • 每次手動點擊左側的菜單,我將Ajax地址的查詢內容(?後面的)附在demo HTML頁面地址後面,使用history.pushState塞到瀏覽器歷史中。
  • 瀏覽器的前進與後退,會觸發window.onpopstate事件,經過綁定popstate事件,就能夠根據當前URL地址中的查詢內容讓對應的菜單執行Ajax載入,實現Ajax的前進與後退效果。
  • 頁面首次載入的時候,若是沒有查詢地址、或查詢地址不匹配,則使用第一個菜單的Ajax地址的查詢內容,並使用history.replaceState更改當前的瀏覽器歷史,而後觸發Ajax操做。

因而,你會看到:

  • 頁面首次載入,雖然咱們訪問的URL的後綴是光禿禿的.html,可是,實際URL最後是: 首次載入頁面的URL

     

    由於被history.replaceState擺了一道。

  • 鼠標點擊左邊的任意一個菜單,會發現,右側內容雖然是Ajax載入,可是,頁面的URL地址卻變了,例如,點擊寶山區: 點擊寶山區URL地址變化

     

    由於歷史記錄被history.pushState插了一刀。

  • 此時,咱們點擊地址欄的後退按鈕,就是這個: 點擊後退、查看歷史記錄

     

    奇蹟般的,頁面無刷新的,又回到了浦東菜單: 回到了浦東,同時出現了歷史前進按鈕

    由於window.onpopstate讓菊花刀又拔了出來。

4、其它點什麼

  • history.pushState 菊花插一刀之意,用法舉例:

     

    history.pushState({}, "頁面標題", "xxx.html");
  • history.pushStatehistory.replaceState 換把菊花刀之意,用法舉例:

     

    history.replaceState(null, "頁面標題", "xxx.html");
  • window.onpopstate 在菊花刀拔插的時候……,用法舉例:

     

    window.addEventListener("popstate", function() {
        var currentState = history.state;
        /*
         * 該幹嗎幹嗎
        */											
    });

瀏覽器兼容性表:

Feature Chrome Firefox (Gecko) Internet Explorer Opera Safari
replaceState, pushState 5 4.0 (2.0) 10 11.50 5.0
history.state 18 4.0 (2.0) 10 11.50 6.0
相關文章
相關標籤/搜索