這篇文章將為大家詳細(xì)講解有關(guān)ajax不能后退的原因有哪些,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
目前創(chuàng)新互聯(lián)已為1000多家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機(jī)、網(wǎng)站運(yùn)營、企業(yè)網(wǎng)站設(shè)計(jì)、杜集網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
因?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無法后退問題實(shí)例
都知道ajax有一個(gè)明顯的缺點(diǎn)就是與瀏覽器的history.back()與forward()不友好,不能前進(jìn)與后退。
實(shí)例地址:解決ajax無法后退問題實(shí)例
解決方法:
window.history實(shí)例
在console里面打印出window.history的實(shí)例,可以查看相關(guān)對(duì)象的原型。
length:length為瀏覽記錄隊(duì)列長度,由于這個(gè)頁面是新打開的,隊(duì)列中只有當(dāng)前頁面鏈接相關(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ù)器上的話應(yīng)該是沒有這個(gè)錯(cuò)誤的。
所以這里的解題思路:
1.每次手動(dòng)點(diǎn)擊左側(cè)的菜單,我將Ajax地址的查詢內(nèi)容(?后面的)附在demo HTML頁面地址后面,使用history.pushState塞到瀏覽器歷史中。
2.瀏覽器的前進(jìn)與后退,會(huì)觸發(fā)window.onpopstate事件,通過綁定popstate事件,就可以根據(jù)當(dāng)前URL地址中的查詢內(nèi)容讓對(duì)應(yīng)的菜單執(zhí)行Ajax載入,實(shí)現(xiàn)Ajax的前進(jìn)與后退效果。
3.頁面首次載入的時(shí)候,如果沒有查詢地址、或查詢地址不匹配,則使用第一個(gè)菜單的Ajax地址的查詢內(nèi)容,并使用history.replaceState更改當(dāng)前的瀏覽器歷史,然后觸發(fā)Ajax操作。
關(guān)于“ajax不能后退的原因有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
當(dāng)前標(biāo)題:ajax不能后退的原因有哪些
網(wǎng)頁URL:http://jinyejixie.com/article2/pdsdoc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、App開發(fā)、企業(yè)建站、外貿(mào)建站、微信公眾號(hào)、關(guān)鍵詞優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)