javascript - vue单页应用阻止浏览器后退?
问题描述
web app 单页应用,是用vue vue-router写的。
有些页面是需要禁止后退的,我把当前页面是否能后退写在了路由元信息meta里面,比如为allowBack。
查到资料 禁止后退的方法是
history.pushState(null, null, location.href)
之前项目用的是vue1.0,解决方法是
1. 在全局的router.beforeEach 里面 判断当前路由的handler里面的allowBack变量是否为false
2. 如果为false 则 history.pushState(null, null, location.href)
现在改用vue2.0, 原来的方法不好使了,
现在的问题是,不知道该把 history.pushState(null, null, location.href) 这段代码放在哪
或者说 各位大神 有没有什么其他的解决方案? 谢谢!!
其实主要的使用场景是这样的,
tabbar点击切换到不同的页面,假如我现在在a页面,点击tabbar到b页面,我不能通过返回键回到a页面,但是能通过点击tabbar去到a页面
自问自答.....
需求是:需要某个路由不能通过浏览器返回,同时不影响相互之间的切换
整理一下解决方法 和 使用方法:
1.在路由配置中给这个路由添加meta信息,比如:
{
path: '/home',
component: xxx,
meta: {allowBack: false}
}
2.在全局的router.beforeEach 函数里面获取allowBack的状态,同时更新vuex的allowBack的值,如:
let allowBack = true // 给个默认值true
if (to.meta.allowBack !== undefined) {
allowBack = to.meta.allowBack
}
if (!allowBack) {
history.pushState(null, null, location.href)
}
store.dispatch('updateAppSetting', {
allowBack: allowBack
})
这段代码得写在next()的后面,因为写在next()前面location.href并不是to的地址,这点跟vue1.0有点不同
-----更新分割线-----
location.href 获取的仍不是to的地址,所以得根据to的信息来拼起来
3.接下来就是最核心的了,在app.vue的mounted里面写onpopstate事件:
window.onpopstate = () => {
if (!this.allowBack) { // 这个allowBack 是存在vuex里面的变量
history.go(1)
}
}
这篇关于javascript - vue单页应用阻止浏览器后退?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!