javascript - vue單頁(yè)應(yīng)用阻止瀏覽器后退?
問(wèn)題描述
web app 單頁(yè)應(yīng)用,是用vue vue-router寫(xiě)的。
有些頁(yè)面是需要禁止后退的,我把當(dāng)前頁(yè)面是否能后退寫(xiě)在了路由元信息meta里面,比如為allowBack。
查到資料 禁止后退的方法是 history.pushState(null, null, location.href)
之前項(xiàng)目用的是vue1.0,解決方法是
1. 在全局的router.beforeEach 里面 判斷當(dāng)前路由的handler里面的allowBack變量是否為false2. 如果為false 則 history.pushState(null, null, location.href)
現(xiàn)在改用vue2.0, 原來(lái)的方法不好使了,
現(xiàn)在的問(wèn)題是,不知道該把 history.pushState(null, null, location.href) 這段代碼放在哪 或者說(shuō) 各位大神 有沒(méi)有什么其他的解決方案? 謝謝??!
其實(shí)主要的使用場(chǎng)景是這樣的, tabbar點(diǎn)擊切換到不同的頁(yè)面,假如我現(xiàn)在在a頁(yè)面,點(diǎn)擊tabbar到b頁(yè)面,我不能通過(guò)返回鍵回到a頁(yè)面,但是能通過(guò)點(diǎn)擊tabbar去到a頁(yè)面
問(wèn)題解答
回答1:自問(wèn)自答.....需求是:需要某個(gè)路由不能通過(guò)瀏覽器返回,同時(shí)不影響相互之間的切換整理一下解決方法 和 使用方法:
1.在路由配置中給這個(gè)路由添加meta信息,比如:
{ path: ’/home’, component: xxx, meta: {allowBack: false}}
2.在全局的router.beforeEach 函數(shù)里面獲取allowBack的狀態(tài),同時(shí)更新vuex的allowBack的值,如:
let allowBack = true // 給個(gè)默認(rèn)值trueif (to.meta.allowBack !== undefined) { allowBack = to.meta.allowBack if (!allowBack) {history.pushState(null, null, location.href) }} store.dispatch(’updateAppSetting’, { allowBack: allowBack})
這段代碼得寫(xiě)在next()的后面,因?yàn)閷?xiě)在next()前面location.href并不是to的地址,這點(diǎn)跟vue1.0有點(diǎn)不同
3.接下來(lái)就是最核心的了,在app.vue的mounted里面注冊(cè)onpopstate事件:
window.onpopstate = () => { if (!this.allowBack) { // 這個(gè)allowBack 是存在vuex里面的變量history.go(1) }}
去掉history.pushState(null, null, location.href) 也能防止后退,但是組件會(huì)重新渲染,所以這部分也很關(guān)鍵
回答2:試試這樣看看
//改寫(xiě)返回函數(shù),返回的時(shí)候就會(huì)觸發(fā)這個(gè),//你也可以直接監(jiān)聽(tīng)瀏覽器的返回事件,定義一個(gè)變量就行了,邏輯跟這個(gè)差不多Router.prototype.goBack = function () { this.isBack = true window.history.go(-1)}//假如當(dāng)前頁(yè)面是b頁(yè)面,是由a頁(yè)面點(diǎn)擊過(guò)來(lái)的,現(xiàn)在b頁(yè)面點(diǎn)擊返回鍵,不能返回到a頁(yè)面router.beforeEach( (to, from, next) => { //一當(dāng)點(diǎn)擊返回鍵,那么to就是a頁(yè)面,from就是b頁(yè)面 if(!from.meta.allowBack){//進(jìn)行頁(yè)面判斷,取出history里面之前的url,對(duì)這個(gè)url進(jìn)行判斷,看他等不等于to這個(gè)頁(yè)面//因?yàn)榘踩颍琷s沒(méi)法獲取history里的url,或者獲取麻煩,所以你就要自己來(lái)記住url//就是每進(jìn)入一個(gè)頁(yè)面,你都去把之前的頁(yè)面路徑存在sessionStorage中//···判斷過(guò)程省略//這里取出,然后對(duì)比就可以了//如果等于的話,直接禁止//取出結(jié)果var path = sessionStorage.getItem(’path’);//這個(gè)this我沒(méi)有實(shí)驗(yàn),應(yīng)是指向router if(path == to.path && this.isBack){ //什么都不做,只要不執(zhí)行next方法,路由是不會(huì)跳的 this.isBack = false; } else { //否則的話,就代表不是點(diǎn)擊的返回鍵,該跳轉(zhuǎn)就跳轉(zhuǎn) //這里也存儲(chǔ) sessionStorage.setItem(’path’,from.path); this.isBack = false; next() } }else{//在這里存儲(chǔ)sessionStorage.setItem(’path’,from.path);this.isBack = false;next(); }});
相關(guān)文章:
1. java - 關(guān)于i++的一個(gè)題目3. apache - 想把之前寫(xiě)的單機(jī)版 windows 軟件改成網(wǎng)絡(luò)版,讓每個(gè)用戶(hù)可以注冊(cè)并登錄。類(lèi)似 qq 的登陸,怎么架設(shè)服務(wù)器呢?4. webgl - android上類(lèi)似汽車(chē)之家的3d全景照片怎么實(shí)現(xiàn)5. css3 - Typecho 后臺(tái)部分表單按鈕在 Chrome 下出現(xiàn)靈異動(dòng)畫(huà)問(wèn)題,求解決6. java - 阿里的開(kāi)發(fā)手冊(cè)中為什么禁用map來(lái)作為查詢(xún)的接受類(lèi)?7. python - uwsgi+django的搭建問(wèn)題8. python - Pycharm的Debug用不了9. 創(chuàng)建mysqli對(duì)象與數(shù)據(jù)庫(kù)連接 - 出錯(cuò)10. 請(qǐng)教MVC分發(fā)控制器時(shí)的相關(guān)內(nèi)容
