十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
這篇文章主要介紹pushState、replaceState、onpopstate如何實現(xiàn)Ajax頁面的前進后退刷新功能,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
創(chuàng)新互聯(lián)公司為企業(yè)提供:品牌網(wǎng)站建設(shè)、網(wǎng)絡(luò)營銷策劃、成都小程序開發(fā)、營銷型網(wǎng)站建設(shè)和網(wǎng)站運營托管,一站式網(wǎng)絡(luò)營銷整體服務(wù)。實現(xiàn)不斷獲取潛在客戶之核心目標(biāo),建立了企業(yè)專屬的“營銷型網(wǎng)站建設(shè)”,就用不著再為了獲取潛在客戶而苦惱,相反,客戶會主動找您,生意就找上門來了!
使用Ajax可以異步獲取數(shù)據(jù),可以更高效地渲染頁面。
但也存在這一些問題:
再刷新頁面,頁面就會變成初始的狀態(tài)
瀏覽器的前進后退功能無效
對搜索引擎的爬蟲抓取不友好
1、
早前會使用瀏覽器的 hash錨點 來解決
不同的hash標(biāo)記著頁面不同的部分,能修正頁面刷新數(shù)據(jù)不正確的問題
再通過 onhashchange 事件監(jiān)聽hash錨點的變化,手動進行前進后退操作,瀏覽器支持度
2、
隨后出現(xiàn)一種 hashbang 的技術(shù),即在url后加上標(biāo)記 #!/myPath 來解決上述的問題
通過一個路徑定義一個頁面部分,在單頁面應(yīng)用中可常見到(Angular中已經(jīng)封裝了)。但好像只有g(shù)oogle真正支持了對該路徑的爬取
3、
HTML5的新特性做了助力,通過pushState、replaceState 這兩個新的history方法和 onpopstate 這個window事件,解決了上述三個問題
當(dāng)然,也因為是HTML5的新特性,在舊版本瀏覽器上支持度不好的,建議是再用hashbang的方法來兼容
本文主要講講pushState這幾個新東西
文字太枯燥了,先看看圖示直接點感受
這個栗子目的是:初始值為0,通過異步請求自增值,可以前進或后退以及刷新,新打開一個url后也能獲取相應(yīng)的數(shù)據(jù)
history.pushState(state, title, url) history.replaceState(state, title, url)
其中state是個json對象,可以自定義存放一些數(shù)據(jù),title即是這個url對應(yīng)的標(biāo)簽title(不過好像瀏覽器都忽略了這個參數(shù))
url是某個頁面的標(biāo)記url(操作只會改變地址欄的url,并不會立馬加載這個url,可以簡單的標(biāo)記 ?w=a、ajaxPage.html/w=a、&w=a,只是一種標(biāo)記,取值時對照著來就行)
replaceState和pushState的不同是:前者直接替換當(dāng)前值,后者就是向棧中壓入一個值
window.onpopstate 事件觸發(fā)之后,可以通過 history.state獲取到上述方法的第一個json對象
實現(xiàn)部分
HTML
value: 0
JS
var $val = $('#ajax-test-val'), // 獲取當(dāng)前頁面的標(biāo)記 m = window.location.search.match(/\?val=(\d+)/); // 新進入頁面,通過url中的標(biāo)記初始化數(shù)據(jù) if (m) { increaseVal(m[1] - 1); } // 請求 function increaseVal(val) { $.post('ajax-test.php', { val: val }, function(newVal) { $val.text(newVal); // 存儲相關(guān)值至對象中 var state = { val: newVal, title: 'title-' + newVal, url: '?val=' + newVal } // 將相關(guān)值壓入history棧中 window.history.pushState && window.history.pushState(state, state.title, state.url); }); } $('#ajax-test-btn').click(function() { increaseVal(parseInt($val.text(), 10)); }); // 瀏覽器的前進后退,觸發(fā)popstate事件 window.onpopstate = function() { var state = window.history.state; console.log(state) // 直接將值取出,或再次發(fā)個ajax請求 $val.text(state.val); window.history.replaceState && window.history.replaceState(state, state.title, state.url); };
PHP
這里通過?val=num 的方式,標(biāo)記了不同的ajax結(jié)果頁
Tips:
使用pushState之后,當(dāng)前進后退觸發(fā)了popstate事件,獲取到相應(yīng)的json對象
json對象的數(shù)據(jù)可自定義
可簡單地存儲相關(guān)標(biāo)記再發(fā)個請求,或者直接將該標(biāo)記頁對應(yīng)的結(jié)果直接存起來
隨著后退操作,地址欄url得到了更新,異步的數(shù)據(jù)也得到了更新
刷新頁面或新打開頁面,就要根據(jù)url中的標(biāo)記去請求數(shù)據(jù)了
要記住的是,瀏覽器并不會自動加載url這部分標(biāo)記對應(yīng)的這個異步內(nèi)容頁,需要我們?nèi)カ@取
ajax是一種在無需重新加載整個網(wǎng)頁的情況下,能夠更新部分網(wǎng)頁的技術(shù),可以通過在后臺與服務(wù)器進行少量數(shù)據(jù)交換,使網(wǎng)頁實現(xiàn)異步更新。
以上是“pushState、replaceState、onpopstate如何實現(xiàn)Ajax頁面的前進后退刷新功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!