vue-router next(false) 禁止訪問某個頁面時,不保留歷史訪問記錄問題
用戶正常訪問流程為 產(chǎn)品列表頁面【a頁面】->產(chǎn)品詳情頁面(選擇不同的計劃價格因素后點擊購買)【b頁面】->產(chǎn)品購買頁面【c頁面】
下面進行如下操作
c頁面 按 <- 返回鍵 返回了b頁面,
而B頁面想通過 -> 前進鍵 回到 c頁面。
這樣的操作是不被允許的。
于是
我寫了如下代碼
/** 防止從填寫表單頁面后退之后又前進,會丟失之前所選擇的計劃價格和價格因素 */ beforeRouteEnter (to, from, next) { if (from.name === 'orderInput') { sessionStorage.setItem('preventForward', true) } next() }, beforeRouteLeave (to, from, next) { // 如果是從表單填寫頁返回的并且不是通過購買按鈕去往表單填寫頁面 if (to.name === 'orderInput' && sessionStorage.getItem('preventForward') === 'true') { this.showToast('請點擊購買按鈕進行購買') next(false) } else { next() } }, method:{ buy(){ sessionStorage.setItem('preventForward', false) } }
但是這個操作會有一個問題,當我阻止了一次去往c頁面的操作next(false)之后, 如果在b頁面 按返回鍵, 按我們預想的,應該要返回a頁面。
可這個時候,實際會返回到 c頁面。
原因就是c頁面雖然被我們阻止了,卻進入了歷史棧中, 我想了個方法來防止這個被禁止的請求加入到棧中。
也就是在 next(false) 前面加入
this.$router.go(-1)
整體代碼
如下:
beforeRouteEnter (to, from, next) { if (from.name === 'orderInput') { sessionStorage.setItem('preventForward', true) } next() }, beforeRouteLeave (to, from, next) { // 如果是從表單填寫頁返回的并且不是通過購買按鈕去往表單填寫頁面 if (to.name === 'orderInput' && sessionStorage.getItem('preventForward') === 'true') { this.$router.go(-1) this.showToast('請點擊購買按鈕進行購買') //這里把next(false)也去掉。兼容移動端。否則在微信操作時,會重復提醒上面那句話 // next(false) } else { next() } }, method:{ buy(){ sessionStorage.setItem('preventForward', false) } }
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
vue用戶長時間不操作退出到登錄頁的兩種實現(xiàn)方式
出于安全考慮,用戶長時間不操作,就回到登錄頁面,讓用戶重新登錄,本文就記錄一下實現(xiàn)這種效果的兩種方式,具有一定的參考價值,感興趣的可以了解一下2021-09-09html中引入Vue.js的cdn實現(xiàn)簡單的文檔單頁
這篇文章主要為大家介紹了html中引入Vue.js的cdn實現(xiàn)簡單的文檔單頁示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08vue+ElementUI實現(xiàn)訂單頁動態(tài)添加產(chǎn)品數(shù)據(jù)效果實例代碼
本篇文章主要介紹了vue+ElementUI實現(xiàn)訂單頁動態(tài)添加產(chǎn)品效果實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07Vue.js分頁組件實現(xiàn):diVuePagination的使用詳解
這篇文章主要介紹了Vue.js分頁組件實現(xiàn):diVuePagination的使用詳解,需要的朋友可以參考下2018-01-01