溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ajax不能后退的原因有哪些

發(fā)布時(shí)間:2021-12-17 15:34:55 來(lái)源:億速云 閱讀:141 作者:小新 欄目:web開(kāi)發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)ajax不能后退的原因有哪些,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

因?yàn)閍jax與瀏覽器的history.back()與forward()不友好,不能前進(jìn)與后退,其解決辦法就是根據(jù)當(dāng)前URL地址中的查詢內(nèi)容讓對(duì)應(yīng)的菜單執(zhí)行Ajax載入即可。

本文操作環(huán)境:windows7系統(tǒng)、javascript1.8.5版、Dell G3電腦。

解決ajax無(wú)法后退問(wèn)題實(shí)例

都知道ajax有一個(gè)明顯的缺點(diǎn)就是與瀏覽器的history.back()與forward()不友好,不能前進(jìn)與后退。

實(shí)例地址:解決ajax無(wú)法后退問(wèn)題實(shí)例

解決方法:

ajax不能后退的原因有哪些ajax不能后退的原因有哪些

window.history實(shí)例

在console里面打印出window.history的實(shí)例,可以查看相關(guān)對(duì)象的原型。

length:length為瀏覽記錄隊(duì)列長(zhǎng)度,由于這個(gè)頁(yè)面是新打開(kāi)的,隊(duì)列中只有當(dāng)前頁(yè)面鏈接相關(guān)信息,其值為1

state:

pushState:就是window.history.pushState();

replaceState:就是window.replaceState();

用法:

window.history.pushState({status: 0} ,'' ,'?data=1');

ajax不能后退的原因有哪些ajax不能后退的原因有哪些

改變后的瀏覽器地址

這里需要注意的是,如果實(shí)在本地運(yùn)行的話,在ie和火狐上都是可以完美運(yùn)行的,但是現(xiàn)在新版的谷歌會(huì)報(bào)錯(cuò),這是因?yàn)楣雀璧陌踩珯C(jī)制問(wèn)題。如果代碼放在服務(wù)器上的話應(yīng)該是沒(méi)有這個(gè)錯(cuò)誤的。

ajax不能后退的原因有哪些ajax不能后退的原因有哪些

所以這里的解題思路:

1.每次手動(dòng)點(diǎn)擊左側(cè)的菜單,我將Ajax地址的查詢內(nèi)容(?后面的)附在demo HTML頁(yè)面地址后面,使用history.pushState塞到瀏覽器歷史中。

2.瀏覽器的前進(jìn)與后退,會(huì)觸發(fā)window.onpopstate事件,通過(guò)綁定popstate事件,就可以根據(jù)當(dāng)前URL地址中的查詢內(nèi)容讓對(duì)應(yīng)的菜單執(zhí)行Ajax載入,實(shí)現(xiàn)Ajax的前進(jìn)與后退效果。

3.頁(yè)面首次載入的時(shí)候,如果沒(méi)有查詢地址、或查詢地址不匹配,則使用第一個(gè)菜單的Ajax地址的查詢內(nèi)容,并使用history.replaceState更改當(dāng)前的瀏覽器歷史,然后觸發(fā)Ajax操作。

關(guān)于“ajax不能后退的原因有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI