pushState、replaceState、onpopstate 實現Ajax頁面的前進後退重新整理_AJAX相關

來源:互聯網
上載者:User

使用Ajax可以非同步擷取資料,可以更高效地渲染頁面。

但也存在這一些問題:

再重新整理頁面,頁面就會變成初始的狀態

瀏覽器的前進後退功能無效

對搜尋引擎的爬蟲抓取不友好

1、

早前會使用瀏覽器的 hash錨點 來解決

不同的hash標記著頁面不同的部分,能修正頁面重新整理資料不正確的問題

再通過 onhashchange 事件監聽hash錨點的變化,手動進行前進後退操作,瀏覽器支援度

2、

隨後出現一種 hashbang 的技術,即在url後加上標記 #!/myPath 來解決上述的問題

通過一個路徑定義一個頁面部分,在單頁面應用中可常見到(Angular中已經封裝了)。但好像只有google真正支援了對該路徑的爬取

3、

HTML5的新特性做了助力,通過pushState、replaceState 這兩個新的history方法和 onpopstate 這個window事件,解決了上述三個問題

當然,也因為是HTML5的新特性,在舊版本瀏覽器上支援度不好的,建議是再用hashbang的方法來相容

本文主要講講pushState這幾個新東西

文字太枯燥了,先看看圖示直接點感受

這個栗子目的是:初始值為0,通過非同步請求自增值,可以前進或後退以及重新整理,新開啟一個url後也能擷取相應的資料

history.pushState(state, title, url)history.replaceState(state, title, url)

其中state是個json對象,可以自訂存放一些資料,title即是這個url對應的標籤title(不過好像瀏覽器都忽略了這個參數)

url是某個頁面的標記url(操作只會改變地址欄的url,並不會立馬載入這個url,可以簡單的標記 ?w=a、ajaxPage.html/w=a、&w=a,只是一種標記,取值時對照著來就行)

replaceState和pushState的不同是:前者直接替換當前值,後者就是向棧中壓入一個值

window.onpopstate 事件觸發之後,可以通過 history.state擷取到上述方法的第一個json對象

實現部分

HTML

<div class="push-state-test"><input type="button" id="ajax-test-btn" value="Ajax擷取"><p>value: <span id="ajax-test-val">0</span></p></div>

JS

var $val = $('#ajax-test-val'),// 擷取當前頁面的標記m = window.location.search.match(/\?val=(\d+)/);// 新進入頁面,通過url中的標記初始化資料if (m) {increaseVal(m[1] - 1);}// 請求function increaseVal(val) {$.post('ajax-test.php', {val: val}, function(newVal) {$val.text(newVal);// 儲存相關值至對象中var state = {val: newVal,title: 'title-' + newVal,url: '?val=' + newVal}// 將相關值壓入history棧中window.history.pushState && window.history.pushState(state, state.title, state.url);});}$('#ajax-test-btn').click(function() {increaseVal(parseInt($val.text(), 10));});// 瀏覽器的前進後退,觸發popstate事件window.onpopstate = function() {var state = window.history.state;console.log(state)// 直接將值取出,或再次發個ajax請求$val.text(state.val);window.history.replaceState && window.history.replaceState(state, state.title, state.url);};

PHP

<?php$val = $_REQUEST['val'];echo $val + 1;?>

這裡通過?val=num 的方式,標記了不同的ajax結果頁

Tips:

使用pushState之後,當前進後退觸發了popstate事件,擷取到相應的json對象

json對象的資料可自訂

可簡單地儲存相關標記再發個請求,或者直接將該標記頁對應的結果直接存起來

隨著後退操作,地址欄url得到了更新,非同步資料也得到了更新

重新整理頁面或新開啟頁面,就要根據url中的標記去請求資料了

要記住的是,瀏覽器並不會自動載入url這部分標記對應的這個非同步內容頁,需要我們去擷取

以上所述是小編給大家介紹的pushState、replaceState、onpopstate 實現Ajax頁面的前進後退重新整理,希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對雲棲社區網站的支援!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.