日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

ajax为什么不能后退

發布時間:2023/12/31 综合教程 30 生活家
生活随笔 收集整理的這篇文章主要介紹了 ajax为什么不能后退 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

因為ajax與瀏覽器的history.back()與forward()不友好,不能前進與后退,其解決辦法就是根據當前URL地址中的查詢內容讓對應的菜單執行Ajax載入即可。

本文操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

ajax為什么不能后退?解決ajax無法后退問題實例

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

實例地址:解決ajax無法后退問題實例

解決方法:

window.history實例

在console里面打印出window.history的實例,可以查看相關對象的原型。

length:length為瀏覽記錄隊列長度,由于這個頁面是新打開的,隊列中只有當前頁面鏈接相關信息,其值為1

state:

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

replaceState:就是window.replaceState();

用法:

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

改變后的瀏覽器地址

這里需要注意的是,如果實在本地運行的話,在ie和火狐上都是可以完美運行的,但是現在新版的谷歌會報錯,這是因為谷歌的安全機制問題。如果代碼放在服務器上的話應該是沒有這個錯誤的。

所以這里的解題思路:

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

2.瀏覽器的前進與后退,會觸發window.onpopstate事件,通過綁定popstate事件,就可以根據當前URL地址中的查詢內容讓對應的菜單執行Ajax載入,實現Ajax的前進與后退效果。

3.頁面首次載入的時候,如果沒有查詢地址、或查詢地址不匹配,則使用第一個菜單的Ajax地址的查詢內容,并使用history.replaceState更改當前的瀏覽器歷史,然后觸發Ajax操作。

推薦學習:《ajax視頻教程》

總結

以上是生活随笔為你收集整理的ajax为什么不能后退的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。