您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(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í)例
解決方法:
在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');
這里需要注意的是,如果實(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ò)誤的。
所以這里的解題思路:
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)把它分享出去讓更多的人看到。
免責(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)容。