主頁 > 知識(shí)庫 > pushState、replaceState、onpopstate 實(shí)現(xiàn)Ajax頁面的前進(jìn)后退刷新

pushState、replaceState、onpopstate 實(shí)現(xiàn)Ajax頁面的前進(jìn)后退刷新

熱門標(biāo)簽:團(tuán)購(gòu)網(wǎng)站 Mysql連接數(shù)設(shè)置 科大訊飛語音識(shí)別系統(tǒng) Linux服務(wù)器 阿里云 電子圍欄 銀行業(yè)務(wù) 服務(wù)器配置

使用Ajax可以異步獲取數(shù)據(jù),可以更高效地渲染頁面。

但也存在這一些問題:

再刷新頁面,頁面就會(huì)變成初始的狀態(tài)

瀏覽器的前進(jìn)后退功能無效

對(duì)搜索引擎的爬蟲抓取不友好

1、

早前會(huì)使用瀏覽器的 hash錨點(diǎn) 來解決

不同的hash標(biāo)記著頁面不同的部分,能修正頁面刷新數(shù)據(jù)不正確的問題

再通過 onhashchange 事件監(jiān)聽hash錨點(diǎn)的變化,手動(dòng)進(jìn)行前進(jìn)后退操作,瀏覽器支持度

2、

隨后出現(xiàn)一種 hashbang 的技術(shù),即在url后加上標(biāo)記 #!/myPath 來解決上述的問題

通過一個(gè)路徑定義一個(gè)頁面部分,在單頁面應(yīng)用中可常見到(Angular中已經(jīng)封裝了)。但好像只有g(shù)oogle真正支持了對(duì)該路徑的爬取

3、

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

當(dāng)然,也因?yàn)槭荋TML5的新特性,在舊版本瀏覽器上支持度不好的,建議是再用hashbang的方法來兼容

本文主要講講pushState這幾個(gè)新東西

文字太枯燥了,先看看圖示直接點(diǎn)感受

這個(gè)栗子目的是:初始值為0,通過異步請(qǐng)求自增值,可以前進(jìn)或后退以及刷新,新打開一個(gè)url后也能獲取相應(yīng)的數(shù)據(jù)

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

其中state是個(gè)json對(duì)象,可以自定義存放一些數(shù)據(jù),title即是這個(gè)url對(duì)應(yīng)的標(biāo)簽title(不過好像瀏覽器都忽略了這個(gè)參數(shù))

url是某個(gè)頁面的標(biāo)記url(操作只會(huì)改變地址欄的url,并不會(huì)立馬加載這個(gè)url,可以簡(jiǎn)單的標(biāo)記 ?w=a、ajaxPage.html/w=a、w=a,只是一種標(biāo)記,取值時(shí)對(duì)照著來就行)

replaceState和pushState的不同是:前者直接替換當(dāng)前值,后者就是向棧中壓入一個(gè)值

window.onpopstate 事件觸發(fā)之后,可以通過 history.state獲取到上述方法的第一個(gè)json對(duì)象

實(shí)現(xiàn)部分

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'),
// 獲取當(dāng)前頁面的標(biāo)記
m = window.location.search.match(/\&;val=(\d+)/);
// 新進(jìn)入頁面,通過url中的標(biāo)記初始化數(shù)據(jù)
if (m) {
increaseVal(m[1] - 1);
}
// 請(qǐng)求
function increaseVal(val) {
$.post('ajax-test.php', {
val: val
}, function(newVal) {
$val.text(newVal);
// 存儲(chǔ)相關(guān)值至對(duì)象中
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));
});
// 瀏覽器的前進(jìn)后退,觸發(fā)popstate事件
window.onpopstate = function() {
var state = window.history.state;
console.log(state)
// 直接將值取出,或再次發(fā)個(gè)ajax請(qǐng)求
$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 的方式,標(biāo)記了不同的ajax結(jié)果頁

Tips:

使用pushState之后,當(dāng)前進(jìn)后退觸發(fā)了popstate事件,獲取到相應(yīng)的json對(duì)象

json對(duì)象的數(shù)據(jù)可自定義

可簡(jiǎn)單地存儲(chǔ)相關(guān)標(biāo)記再發(fā)個(gè)請(qǐng)求,或者直接將該標(biāo)記頁對(duì)應(yīng)的結(jié)果直接存起來

隨著后退操作,地址欄url得到了更新,異步的數(shù)據(jù)也得到了更新

刷新頁面或新打開頁面,就要根據(jù)url中的標(biāo)記去請(qǐng)求數(shù)據(jù)了

要記住的是,瀏覽器并不會(huì)自動(dòng)加載url這部分標(biāo)記對(duì)應(yīng)的這個(gè)異步內(nèi)容頁,需要我們?nèi)カ@取

以上所述是小編給大家介紹的pushState、replaceState、onpopstate 實(shí)現(xiàn)Ajax頁面的前進(jìn)后退刷新,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • 使用Yii整合的pjax(pushstate+ajax)實(shí)現(xiàn)無刷新加載頁面
  • 使用ajax和history.pushState無刷新改變頁面URL示例
  • 使用ajax實(shí)現(xiàn)無刷新改變頁面內(nèi)容和地址欄URL
  • 基于iframe實(shí)現(xiàn)類似于ajax的頁面無刷新
  • ajax頁面無刷新 IE下遭遇Ajax緩存導(dǎo)致數(shù)據(jù)不更新的問題
  • Ajax無刷新Url提交頁面
  • JS+Ajax+Jquery實(shí)現(xiàn)頁面無刷新分頁以及分組 超強(qiáng)的實(shí)現(xiàn)
  • PHP Ajax實(shí)現(xiàn)頁面無刷新發(fā)表評(píng)論
  • PHP Ajax實(shí)現(xiàn)頁面無刷新發(fā)表評(píng)論
  • pushState實(shí)現(xiàn)Ajax無刷新頁面切換

標(biāo)簽:衡水 大理 棗莊 萍鄉(xiāng) 江蘇 廣元 衢州 蚌埠

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《pushState、replaceState、onpopstate 實(shí)現(xiàn)Ajax頁面的前進(jìn)后退刷新》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266