在vue項(xiàng)目中利用popstate處理頁面返回的操作介紹
需求背景:項(xiàng)目中需要做一個返回確認(rèn),避免用戶誤觸返回鍵而退出當(dāng)前頁面。
原理:利用history和瀏覽器刷新popstate狀態(tài)
實(shí)現(xiàn):
1、在mounted() 階段判斷并添加popstate事件監(jiān)聽,History.pushState()(參數(shù):一個狀態(tài)對象,一個標(biāo)題(現(xiàn)在被忽略了),以及一個可選的URL地址), 注意:IOS版的微信,是會立即觸發(fā)popstate事件,所以需要pageshow做下處理,(當(dāng)一條會話歷史記錄被執(zhí)行的時候?qū)|發(fā)頁面顯示(pageshow)事件。(這包括了后退/前進(jìn)按鈕操作,同時也會在onload 事件觸發(fā)后初始化頁面時觸發(fā)))
2、在methods里定義監(jiān)聽操作函數(shù)
3、頁面銷毀時,取消監(jiān)聽。(注意:一定要取消監(jiān)聽,否則其他vue路由頁面也會被監(jiān)聽)
補(bǔ)充知識:vue項(xiàng)目監(jiān)測瀏覽器返回按鈕
在WebApp或?yàn)g覽器中,會有點(diǎn)擊返回、后退、上一頁等按鈕實(shí)現(xiàn)自己的關(guān)閉頁面、調(diào)整到指定頁面、確認(rèn)離開頁面或執(zhí)行一些其它操作的需求。可以使用 popstate 事件進(jìn)行監(jiān)聽返回、后退、上一頁操作。
簡單介紹history中的操作
window.history.back(),后退
window.history.forward(),前進(jìn)
window.history.go(num),前進(jìn)或后退指定數(shù)量歷史記錄
window.history.pushState(state,title,url),在頁面中穿件一個history實(shí)體。直接添加到歷史記錄中。參數(shù): state:儲存一個對象,可以添加相關(guān)信息,可以使用history.state讀取其中的內(nèi)容。title: 歷史記錄的標(biāo)題,url:創(chuàng)建的歷史記錄rul,進(jìn)行歷史記錄操作時會跳轉(zhuǎn)到該鏈接。
window.history.replaceState(),修改當(dāng)前的history實(shí)體。
popstate事件,history實(shí)體改變時觸發(fā)事件
window.history.state,會獲得history實(shí)體中的state對象。
使用方法
取消默認(rèn)的返回操作
添加一條history實(shí)體作為替代原來的history實(shí)體
mounted () { if(window.history&&window.history.pushState){ history.pushState(null,null,document.URL) window.addEventListener('popstate', this.goBack, false); } }, destroyed(){ window.removeEventListener('popstate',this.goBack,false); }, methods:{ goBack(){ this.$router.replace({path:'/'}); //replace替換原路由,作用是避免回退死循環(huán) } }
以上這篇在vue項(xiàng)目中利用popstate處理頁面返回的操作介紹就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue3如何通過provide和inject實(shí)現(xiàn)多層級組件通信
這篇文章主要介紹了vue3如何通過provide和inject實(shí)現(xiàn)多層級組件通信,本文通過實(shí)例代碼給大家講解的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-11-11Vue-Element-Admin集成自己的接口實(shí)現(xiàn)登錄跳轉(zhuǎn)
關(guān)于這個Vue-element-admin中的流程可能對于新的同學(xué)不是很友好,所以本文將結(jié)合實(shí)例代碼,介紹Vue-Element-Admin集成自己的接口實(shí)現(xiàn)登錄跳轉(zhuǎn),感興趣的小伙伴們可以參考一下2021-06-06vue項(xiàng)目中實(shí)現(xiàn)緩存的最佳方案詳解
這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目中實(shí)現(xiàn)緩存的最佳方案,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07vue頁面中使用getElementsByClassName無法獲取元素的解決
這篇文章主要介紹了vue頁面中使用getElementsByClassName無法獲取元素的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03Vue Components 數(shù)字鍵盤的實(shí)現(xiàn)
這篇文章主要介紹了Vue Components 數(shù)字鍵盤的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09