大家好,又见面了,我是你们的朋友全栈君。
前端常常需要实现的一个功能,比如一个商城,跳转到某些页面,如个人中心等就需要登录过才能进去,不然就先跳转到登录页面之后才能跳转到需要登录之后才能查看的页面,此功能就需要导航守卫来完成比较好。
我在项目中用于全局main.js中,判断是否登录,如果登录就继续跳转,没有登录就去跳转页面
const router = new VueRouter({ ... })
router.beforeEach((to, from, next) => {
if (to.matched.some(record => record.meta.requireAuth)) {
// 路由元信息requireAuth:true则不做登录校验
next();
} else {
get(BASE_URL + "login/index").then(res => { //此处接口是问后台是否登录过,这个可以前端自己通过sessionStorage实现或者通过vuex+sessionStorage实现,用一个变量保存是否登录过,或者有没有token判断等方式
if (res.data.code === 200) {
//成功
next();
} else {
if (to.path == "/login" || to.path == "/") {
//如果是登录页面路径,就直接next()
next();
} else {
//不然就跳转到登录;
next({
path: "/login"
// query: { redirect: to.fullPath } //这里是实现路径重定义,方便完成登录动作直接跳转到本页面
});
}
}
}).catch(err => {
console.log(err, "err");
next("/notFindPage");
});
}
});
当一个导航触发时,全局前置守卫按照创建顺序调用。守卫是异步解析执行,此时导航在所有守卫 resolve 完之前一直处于 等待中。
每个守卫方法接收三个参数:
to: Route: 即将要进入的目标 路由对象
from: Route: 当前导航正要离开的路由
next: Function: 一定要调用该方法来 resolve 这个钩子。执行效果依赖 next 方法的调用参数。
next(): 进行下一个钩子。如果全部钩子执行完了,则导航的状态就是 confirmed (确认的),继续跳转。
next(false): 中断当前的导航。如果浏览器的 URL 改变了(可能是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址。
next(’/’) 或者 next({ path: ‘/’ }): 跳转到一个不同的地址。当前的导航被中断,然后进行一个新的导航。
next(error): (2.4.0+) 如果传入 next 的参数是一个 Error 实例,则导航会被终止且该错误会被传递给 router.onError() 注册过的回调。
可以通过路由远信息requireAuth:true指定某一个页面不验证
routes: [
{
path: '/', //这个表示的是根目录,即一进入的页面
redirect: 'login', //设置页面一进来就显示的页面,即重定向到登录页
meta:{
requireAuth:true
}
},
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/148321.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...