在vue項(xiàng)目中利用popstate處理頁(yè)面返回的操作介紹
需求背景:項(xiàng)目中需要做一個(gè)返回確認(rèn),避免用戶誤觸返回鍵而退出當(dāng)前頁(yè)面。
原理:利用history和瀏覽器刷新popstate狀態(tài)
實(shí)現(xiàn):
1、在mounted() 階段判斷并添加popstate事件監(jiān)聽,History.pushState()(參數(shù):一個(gè)狀態(tài)對(duì)象,一個(gè)標(biāo)題(現(xiàn)在被忽略了),以及一個(gè)可選的URL地址), 注意:IOS版的微信,是會(huì)立即觸發(fā)popstate事件,所以需要pageshow做下處理,(當(dāng)一條會(huì)話歷史記錄被執(zhí)行的時(shí)候?qū)?huì)觸發(fā)頁(yè)面顯示(pageshow)事件。(這包括了后退/前進(jìn)按鈕操作,同時(shí)也會(huì)在onload 事件觸發(fā)后初始化頁(yè)面時(shí)觸發(fā)))

2、在methods里定義監(jiān)聽操作函數(shù)

3、頁(yè)面銷毀時(shí),取消監(jiān)聽。(注意:一定要取消監(jiān)聽,否則其他vue路由頁(yè)面也會(huì)被監(jiān)聽)

補(bǔ)充知識(shí):vue項(xiàng)目監(jiān)測(cè)瀏覽器返回按鈕
在WebApp或?yàn)g覽器中,會(huì)有點(diǎn)擊返回、后退、上一頁(yè)等按鈕實(shí)現(xiàn)自己的關(guān)閉頁(yè)面、調(diào)整到指定頁(yè)面、確認(rèn)離開頁(yè)面或執(zhí)行一些其它操作的需求??梢允褂?popstate 事件進(jìn)行監(jiān)聽返回、后退、上一頁(yè)操作。
簡(jiǎn)單介紹history中的操作
window.history.back(),后退
window.history.forward(),前進(jìn)
window.history.go(num),前進(jìn)或后退指定數(shù)量歷史記錄
window.history.pushState(state,title,url),在頁(yè)面中穿件一個(gè)history實(shí)體。直接添加到歷史記錄中。參數(shù): state:儲(chǔ)存一個(gè)對(duì)象,可以添加相關(guān)信息,可以使用history.state讀取其中的內(nèi)容。title: 歷史記錄的標(biāo)題,url:創(chuàng)建的歷史記錄rul,進(jìn)行歷史記錄操作時(shí)會(huì)跳轉(zhuǎn)到該鏈接。
window.history.replaceState(),修改當(dāng)前的history實(shí)體。
popstate事件,history實(shí)體改變時(shí)觸發(fā)事件
window.history.state,會(huì)獲得history實(shí)體中的state對(duì)象。
使用方法
取消默認(rèn)的返回操作
添加一條history實(shí)體作為替代原來(lái)的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處理頁(yè)面返回的操作介紹就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解VUE 對(duì)element-ui中的ElTableColumn擴(kuò)展
本篇文章主要介紹了詳解VUE 對(duì)element-ui中的ElTableColumn擴(kuò)展,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
Vue3優(yōu)雅的實(shí)現(xiàn)跨組件通信的常用方法總結(jié)
開發(fā)中經(jīng)常會(huì)遇到跨組件通信的場(chǎng)景,props?逐層傳遞的方法實(shí)在是太不優(yōu)雅了,所以今天總結(jié)下可以更加簡(jiǎn)單的跨組件通信的一些方法,文中通過(guò)代碼實(shí)例講解的非常詳細(xì),需要的朋友可以參考下2023-11-11
詳解vue-cli項(xiàng)目中的proxyTable跨域問(wèn)題小結(jié)
這篇文章主要介紹了詳解vue-cli項(xiàng)目中的proxyTable跨域問(wèn)題小結(jié),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
Vues中使用JavaScript實(shí)現(xiàn)路由跳轉(zhuǎn)的步驟詳解
在Vue應(yīng)用中,利用Vue?Router進(jìn)行頁(yè)面間的導(dǎo)航是一個(gè)常見需求,本篇博客將通過(guò)示例代碼詳細(xì)介紹如何在Vue組件中使用JavaScript實(shí)現(xiàn)路由跳轉(zhuǎn),需要的朋友可以參考下2024-05-05
聊聊Vue 中 title 的動(dòng)態(tài)修改問(wèn)題
這篇文章主要介紹了 Vue 中 title 的動(dòng)態(tài)修改問(wèn)題,文中通過(guò)兩種方案給大家介紹了title的傳遞問(wèn)題 ,需要的朋友可以參考下2019-06-06
Vue實(shí)現(xiàn)實(shí)時(shí)刷新時(shí)間的功能
這篇文章主要為大家詳細(xì)介紹了如何Vue利用實(shí)現(xiàn)實(shí)時(shí)刷新時(shí)間的功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以了解下2023-12-12
vue.js中v-on:textInput無(wú)法執(zhí)行事件問(wèn)題的解決過(guò)程
大家都知道vue.js通過(guò)v-on完成事件處理與綁定,但最近使用v-on的時(shí)候遇到了一個(gè)問(wèn)題,所以下面這篇文章主要給大家介紹了關(guān)于vue.js中v-on:textInput無(wú)法執(zhí)行事件問(wèn)題的解決過(guò)程,需要的朋友可以參考下。2017-07-07

