vue三种路由守卫详解

在 Vue 中,可以通过路由守卫来实现路由鉴权。Vue 提供了三种路由守卫:全局前置守卫、全局解析守卫和组件内的守卫

  1. 全局前置守卫
    通过 router.beforeEach() 方法实现,可以在路由跳转之前进行权限判断。在这个守卫中,可以根据用户的登录状态、角色等信息来判断用户是否有权限访问该路由。如果没有权限,则可以跳转到登录页面或者其他提示页面。
  2. 全局解析守卫
    通过 router.beforeResolve() 方法实现,可以在路由解析之前进行权限判断。这个守卫可以用于处理异步路由加载的情况,确保在加载路由之前进行权限判断。
  3. 组件内的守卫
    通过 beforeRouteEnter 、 beforeRouteUpdate 和 beforeRouteLeave 这三个钩子函数实现。这些守卫直接在组件内部定义,并且会在组件的路由导航过程中触发。可以用于执行一些与组件相关的逻辑,例如加载组件的数据、检查组件的状态等。

全局前置守卫代码示例

以下是一个示例代码,展示了如何使用全局前置守卫来限制未登录用户的访问:

const router = new VueRouter({

routes: [

{

path: '/',

component: HomeComponent,

},

{

path: '/login',

component: LoginComponent,

},

],

});

router.beforeEach((to, from, next) => {

// 检查用户是否已登录

if (!isLoggedIn) {

next('/login');

} else {

next();

}

});

在这个示例中,定义了一个全局前置守卫,使用 router.beforeEach() 方法来检查用户是否已登录。如果用户未登录,则导航到登录页面,否则允许继续导航。

全局解析守卫的示例代码

这个示例展示了如何使用 router.beforeResolve() 方法进行权限判断:

router.beforeResolve((to, from, next) => {

// 获取要进入的路由组件

const component = to.matched[0].components.default;

// 进行权限检查

if (hasPermission(component)) {

next();

} else {

// 没有权限,跳转到错误页面或执行其他操作

next('/error');

}

});

在这个示例中,使用 router.beforeResolve() 方法定义了全局解析守卫。通过获取要进入的路由组件,并进行权限检查来确定用户是否有权访问该组件。如果有相应权限,就继续导航;否则,跳转到错误页面或执行其他操作。

请注意,全局解析守卫在路由解析完成后触发,也就是在组件被加载之前。这意味着你可以在守卫中进行更复杂的权限检查,例如检查组件的特定属性或与服务器进行异步验证。

三种组件内守卫代码示例

在 Vue.js 中,组件内守卫有三个: beforeRouteEnter 、 beforeRouteUpdate 和 beforeRouteLeave 。以下是一个示例代码,展示了如何使用这三种组件内守卫:

export default {

name: 'About',

// beforeRouteEnter 是进入守卫,通过路由规则,进入该组件时被调用

beforeRouteEnter(to, from, next) {

console.log('About--beforeRouteEnter', to, from)

if (to.meta.isAuth) {

if (localStorage.getItem('school') === 'atguigu') {

next()

} else {

alert('学校名不对,无权限查看!')

}

} else {

next()

}

},

// beforeRouteLeave 是离开守卫,通过路由规则,离开该组件时被调用

beforeRouteLeave(to, from, next) {

console.log('About--beforeRouteLeave', to, from)

next()

},

// beforeRouteUpdate 是更新守卫,组件被复用(例如从缓存中恢复)时被调用

beforeRouteUpdate(to, from, next) {

console.log('About--beforeRouteUpdate', to, from)

next()

}

}

在上述示例中, beforeRouteEnter 守卫会在进入 About 组件时被调用。如果路由规则中设置了 isAuth 元数据并且本地存储中 school 的值为 atguigu ,则允许进入该组件;否则会弹出一个警告框。 beforeRouteLeave 守卫会在离开 About 组件时被调用,它只是简单地继续执行下一个路由。 beforeRouteUpdate 守卫会在组件被复用(例如从缓存中恢复)时被调用,它也只是简单地继续执行下一个路由。

请注意,上述示例代码中的 isAuth 元数据和 localStorage.getItem('school') 是自定义的,你可以根据实际需求进行相应的修改。

相关推荐
Momo__3 小时前
Vue 3.6 Vapor Mode:跳过虚拟 DOM,性能极致优化
前端·vue.js
walking9574 小时前
重新学习前端之JavaScript
前端·vue.js·面试
walking9574 小时前
重新学习前端之HTML
前端·vue.js·面试
walking9574 小时前
重新学习前端之Vue
前端·vue.js·面试
泉城老铁4 小时前
springboot实现word转换pdf
vue.js·后端
walking9574 小时前
重新学习前端之Linux
前端·vue.js·面试
walking9574 小时前
重新学习前端之CSS
前端·vue.js·面试
walking9574 小时前
重新学习前端之Git
前端·vue.js·面试
Hello--_--World5 小时前
Vue指令:v-if vs v-show、v-if 与 v-for 的优先级冲突、自定义指令
前端·javascript·vue.js
Hello--_--World8 小时前
Vue:虚拟Dom
前端·javascript·vue.js