溫馨提示×

溫馨提示×

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

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

html5中如何實(shí)現(xiàn)pushstate以及監(jiān)聽瀏覽器返回事件

發(fā)布時(shí)間:2021-03-20 11:43:49 來源:億速云 閱讀:161 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了html5中如何實(shí)現(xiàn)pushstate以及監(jiān)聽瀏覽器返回事件,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

pushstate與監(jiān)聽瀏覽器返回解決的問題

1.實(shí)際開發(fā)我們在A頁面調(diào)用組件,在組件里面填好內(nèi)容之后,發(fā)現(xiàn)想退出不想填了,因?yàn)榻M件與A頁面此時(shí)在同一頁面,點(diǎn)擊返回時(shí)候 給人感覺是返回上上個(gè)頁面,但之前A頁面填寫的東西 都沒有了,這很影響體驗(yàn)。

因此可以使用pushstate方法,不刷新瀏覽器改變url 當(dāng)你再返回時(shí)候就會(huì)返回到這個(gè)A頁面而不是上上個(gè)頁面。但此時(shí)還需要監(jiān)聽返回的按鈕,進(jìn)而控制組件的顯示與隱藏。這點(diǎn)也至關(guān)重要。不然組件不隱藏,也就相當(dāng)于沒效果。

pushState

使用方法(一般情況)

function pushHistory() { 
var state = { title: "title", url: "#" }; 
window.history.pushState(state, "title", "#"); }

參數(shù)說明:

pushState() 帶有三個(gè)參數(shù):state是js對(duì)象,title是個(gè)標(biāo)題(現(xiàn)在被忽略了),以及一個(gè)可選的URL地址。

關(guān)于pushstate的說明

瀏覽器不會(huì)向服務(wù)端請求數(shù)據(jù),直接改變url地址,可以類似的理解為變相版的hash;但不像hash一樣,瀏覽器會(huì)記錄pushState的歷史記錄,可以使用瀏覽器的前進(jìn)、后退功能作用。

監(jiān)聽瀏覽器返回按鈕

window.addEventListener("popstate", function(e) { console.log(e); alert("我監(jiān)聽到了瀏覽器的返回按鈕事件啦");//根據(jù)自己的需求實(shí)現(xiàn)自己的功能 }, false);

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“html5中如何實(shí)現(xiàn)pushstate以及監(jiān)聽瀏覽器返回事件”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

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

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

AI