首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
第 14 章 基于Vue的网络框架vue-axios的应用
14.1 使用vue-axios请求天气数据
14.1.1 使用互联网上免费的数据服务
14.1.2 使用vue-axios进行数据请求
14.2 vue-axios实用功能介绍
14.2.1 通过配置的方式进行数据请求
14.2.2 请求的配置与响应数据结构
14.2.3 拦截器的使用
14.3 实战:天气预报应用
14.3.1 搭建页面框架
14.3.2 实现天气预报应用核心逻辑
第 15 章 Vue路由管理
15.1 Vue Router的安装与简单使用
15.1.1 Vue Router的安装
15.1.2 一个简单的Vue Router的使用示例
15.2 带参数的动态路由
15.2.1 路由参数匹配
15.2.2 路由匹配的语法规则
15.2.3 路由的嵌套
15.3 页面导航
15.3.1 使用路由方法
15.3.2 导航历史控制
15.4 关于路由的命名
15.4.1 使用名称进行路由切换
15.4.2 路由视图命名
15.4.3 使用别名
15.4.4 路由重定向
15.5 关于路由传参
15.6 路由导航守卫
15.6.1 定义全局的导航守卫
15.6.2 为特定的路由注册导航守卫
15.7 动态路由
第 16 章 Vue状态管理
16.1 认识Vuex框架
16.1.1 关于状态管理
16.1.2 安装与体验Vuex
16.2 Vuex中的一些核心概念
16.2.1 Vuex中的状态state
16.2.2 Vuex中的Getter方法
16.2.3 Vuex中的Mutation
16.2.4 Vuex中的Action
16.2.5 Vuex中的Module 333
当前位置:
首页>>
技术小册>>
TypeScript和Vue从入门到精通(五)
小册名称:TypeScript和Vue从入门到精通(五)
### 15.6 路由导航守卫 在Vue.js应用中,尤其是在使用Vue Router进行单页面应用(SPA)开发时,路由导航守卫(Navigation Guards)是一项至关重要的功能。它们允许我们在路由发生变化的过程中执行代码,比如验证用户权限、设置页面标题、加载数据等。TypeScript与Vue的结合,为这些守卫的编写提供了更强的类型支持和更清晰的代码结构。本章节将深入介绍Vue Router中的路由导航守卫,并展示如何在TypeScript环境中使用它们。 #### 15.6.1 理解路由导航守卫 Vue Router提供了多种导航守卫,这些守卫可以在路由的不同阶段被调用,从而允许我们控制路由的跳转过程。常见的路由导航守卫包括全局守卫、路由独享的守卫以及组件内的守卫。 - **全局守卫**:作用于整个应用,如`beforeEach`和`afterEach`,无论路由如何变化,这些守卫都会被调用。 - **路由独享的守卫**:仅对某个特定的路由有效,如`beforeEnter`。 - **组件内的守卫**:在组件内部定义,包括`beforeRouteEnter`、`beforeRouteUpdate`(Vue 2.2+)、`beforeRouteLeave`。 #### 15.6.2 全局守卫 全局守卫通常在路由配置文件中定义,用于对整个应用的路由跳转进行全局性的控制。 ##### 1. `beforeEach` `beforeEach`是最常用的全局守卫之一,它在路由即将变化之前被调用。你可以在这里进行用户登录验证、重定向到登录页面、设置页面标题等操作。 ```typescript import Vue from 'vue'; import Router from 'vue-router'; import Home from './views/Home.vue'; import Login from './views/Login.vue'; Vue.use(Router); const router = new Router({ routes: [ { path: '/', name: 'home', component: Home }, { path: '/login', name: 'login', component: Login } // 更多路由... ] }); router.beforeEach((to: Route, from: Route, next: Function) => { // 假设我们有一个方法来检查用户是否登录 if (to.matched.some(record => record.meta.requiresAuth)) { // 这里只是模拟,实际情况应检查用户是否登录 if (!isAuthenticated()) { next({ path: '/login', query: { redirect: to.fullPath } // 将尝试访问的路由地址作为参数,登录后重定向回去 }); } else { next(); // 确保一定要调用 next() } } else { next(); // 确保一定要调用 next() } }); function isAuthenticated(): boolean { // 这里应实现具体的登录验证逻辑 return false; // 假设用户未登录 } export default router; ``` 在上面的例子中,我们通过检查路由的`meta`字段来判断是否需要验证用户身份。如果需要,则调用`isAuthenticated`函数来验证,并根据验证结果决定是跳转到登录页面还是继续当前路由的跳转。 ##### 2. `afterEach` 与`beforeEach`相对,`afterEach`守卫在路由跳转完成后被调用,不接受`next`函数,因此不能改变导航本身。它主要用于一些收尾工作,如分析页面停留时间、设置页面标题等。 ```typescript router.afterEach((to: Route, from: Route) => { // 设置页面标题 document.title = to.meta.title || '默认标题'; }); ``` #### 15.6.3 路由独享的守卫 路由独享的守卫只针对某个具体的路由生效,主要通过`beforeEnter`来定义。这在某些特定的路由上执行逻辑时非常有用,而无需全局性地影响其他路由。 ```typescript const router = new Router({ routes: [ { path: '/profile', component: Profile, beforeEnter: (to: Route, from: Route, next: Function) => { // 在这里可以执行针对/profile路由的特定逻辑 // 比如检查用户是否已登录 if (!isAuthenticated()) { next({ path: '/login', query: { redirect: to.fullPath } }); } else { next(); } } } // 其他路由... ] }); ``` #### 15.6.4 组件内的守卫 组件内的守卫允许我们在组件内部对路由的进入、更新和离开进行控制。 ##### 1. `beforeRouteEnter` 在渲染该组件的对应路由被 confirm 前调用,不!能!获取组件实例 `this`。因为当守卫执行前,组件实例还没被创建。 ```typescript export default Vue.extend({ beforeRouteEnter(to: Route, from: Route, next: Function) { // 在渲染该组件的对应路由被 confirm 前调用 // 不!能!获取组件实例 `this` // 当守卫执行前,组件实例还没被创建 next(vm => { // 通过 `vm` 访问组件实例 }); } // 其他选项... }); ``` ##### 2. `beforeRouteUpdate` (Vue 2.2+) 在当前路由改变,但是该组件被复用时调用。例如,对于一个带有动态参数的路径 `/foo/:id`,在 `/foo/1` 和 `/foo/2` 之间跳转的时候,由于会渲染同样的 `Foo` 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。 ```typescript export default Vue.extend({ beforeRouteUpdate(to: Route, from: Route, next: Function) { // 路由更新前调用 // 例如,当一个带有动态参数的路由在变化时,该组件被复用,而你想在每次变化时都执行一些操作 next(); } // 其他选项... }); ``` ##### 3. `beforeRouteLeave` 导航离开该组件的对应路由时调用,可以访问组件实例 `this`。这个守卫通常用于提示用户保存更改,或者阻止用户在表单尚未保存的情况下离开页面。 ```typescript export default Vue.extend({ data() { return { isFormChanged: false }; }, beforeRouteLeave(to: Route, from: Route, next: Function) { if (this.isFormChanged) { const answer = window.confirm('您有未保存的更改,确定离开吗?'); if (answer) { next(); } else { next(false); // 取消路由跳转 } } else { next(); } } // 其他选项... }); ``` #### 15.6.5 总结 路由导航守卫是Vue Router中一个非常强大的功能,它允许我们在路由跳转的不同阶段执行代码,从而控制用户的访问流程、设置页面标题、加载数据等。在TypeScript环境中,利用TypeScript的强类型特性,我们可以编写出更加健壮、易于维护的路由守卫代码。通过合理使用全局守卫、路由独享守卫和组件内守卫,我们可以灵活地控制整个应用的路由逻辑,提升用户体验。
上一篇:
15.5 关于路由传参
下一篇:
15.6.1 定义全局的导航守卫
该分类下的相关小册推荐:
TypeScript和Vue从入门到精通(三)
vue项目构建基础入门与实战
vuejs组件实例与底层原理精讲
VUE组件基础与实战
TypeScript和Vue从入门到精通(一)
Vue.js从入门到精通(四)
Vue源码完全解析
Vue3技术解密
Vue.js从入门到精通(三)
Vue面试指南
TypeScript和Vue从入门到精通(二)
TypeScript和Vue从入门到精通(四)