pushstate與監(jiān)聽瀏覽器返回解決的問題
1.實際開發(fā)我們在A頁面調用組件,在組件里面填好內容之后,發(fā)現(xiàn)想退出不想填了,因為組件與A頁面此時在同一頁面,點擊返回時候 給人感覺是返回上上個頁面,但之前A頁面填寫的東西 都沒有了,這很影響體驗。
因此可以使用pushstate方法,不刷新瀏覽器改變url 當你再返回時候就會返回到這個A頁面而不是上上個頁面。但此時還需要監(jiān)聽返回的按鈕,進而控制組件的顯示與隱藏。這點也至關重要。不然組件不隱藏,也就相當于沒效果。
pushState
使用方法(一般情況)
function pushHistory() {
var state = { title: "title", url: "#" };
window.history.pushState(state, "title", "#"); }
參數(shù)說明:
pushState() 帶有三個參數(shù):state是js對象,title是個標題(現(xiàn)在被忽略了),以及一個可選的URL地址。
關于pushstate的說明
瀏覽器不會向服務端請求數(shù)據(jù),直接改變url地址,可以類似的理解為變相版的hash;但不像hash一樣,瀏覽器會記錄pushState的歷史記錄,可以使用瀏覽器的前進、后退功能作用。
監(jiān)聽瀏覽器返回按鈕
window.addEventListener("popstate", function(e) { console.log(e); alert("我監(jiān)聽到了瀏覽器的返回按鈕事件啦");//根據(jù)自己的需求實現(xiàn)自己的功能 }, false);
轉自:https://segmentfault.com/a/1190000022696823
到此這篇關于html5的pushstate以及監(jiān)聽瀏覽器返回事件的實現(xiàn)的文章就介紹到這了,更多相關html5的pushstate實現(xiàn)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持腳本之家!