动态路由和导航守卫

目录

一、动态路由

1、什么是动态路由?

2、动态路由如何进行参数的传递

3、$route和$router的区别

4、示例

二、路由中的查询参数

1、查询参数的格式

 2、在组件中接收查询参数:this.$route.query.参数名

3、示例:通过查询参数实现动态路由的效果

三、命名路由

1、什么是命名路由?

 2、在 < router-link >中使用name进行映射

四、命名视图

五、声明式导航 & 编程式导航

1、声明式导航:以超链接方式实现的页面跳转,就是声明式导航

2、编程式导航:通过javascript提供的api方法实现页面的跳转,就是编程式导航

3、vue-router中提供的编程式导航的API

六、导航守卫

1、用途:在页面导航过程中实现重定向、取消路由、权限验证等业务

2、分类:全局守卫、组件内部守卫、路由独享的守卫

3、全局守卫:

4、全局前置守卫的使用

一、动态路由

1、什么是动态路由?

​ 将URL地址中可变的内容设置成参数,根据不同的参数渲染不同的组件。(组件可以复用)

2、动态路由如何进行参数的传递

​ (1)如何设置URL地址中的参数:’/url/:参数名’

​ (2)在组件中接收参数:this.$route.params.参数名

3、$route和$router的区别

​ (1)$router:

        ​ A、是VueRouter的实例,是一个全局的路由对象。用户可以在任何地方使用

        ​ B、包含了所有的路由对象(实际代表的路由文件—- 路由表、路由模式)

        ​ C、可以通过$router进行路由跳转(push、replace)

​ (2)$route:

        ​ A、代表当前正在跳转的路由对象,是一个局部对象

        ​ B、每个路由都有一个$route

        ​ C、用法:this.$route后面跟name、path、params、query

4、示例

​ (1)创建数据文件:assets/books.js

​ (2)创建组件:

        ​ Books.vue:显示图书列表(显示图书名称)

        ​ Book.vue:显示图书的详细信息(由路由参数id)

​ (3)创建路由文件:src/router/index.js

​ (4)在main.js文件中注册自定义的路由器

​ (5)在App.vue中通过超链接渲染Books.vue组件

​ (6)修改路由文件:src/router/index.js

​ (7)修改Books.vue中的和

二、路由中的查询参数

1、查询参数的格式

在URL地址中带参数,例如:’/url地址 ?参数名1=参数值1&参数名2=参数值2’

动态路由和导航守卫_第1张图片

 2、在组件中接收查询参数:this.$route.query.参数名

动态路由和导航守卫_第2张图片

3、示例:通过查询参数实现动态路由的效果

(1)修改路由文件:

三、命名路由

1、什么是命名路由?

​ 在路由表中给路由项设置name属性

动态路由和导航守卫_第3张图片

 2、在 < router-link >中使用name进行映射

四、命名视图

1、给< router-view >指定名称:在使用时如没有给< router-view >设置名称,默认为default,可以定义多个路由视图,每个路由视图都指定名称

动态路由和导航守卫_第4张图片

 2、在路由表中给路由项添加components属性:将组件渲染到给定名称的视图中

五、声明式导航 & 编程式导航

1、声明式导航:以超链接方式实现的页面跳转,就是声明式导航

​ < a href=’url’> 链接文本或图像 < /a >

​ < router-link to=’url’ > 链接文本或图像 < /router-link >

2、编程式导航:通过javascript提供的api方法实现页面的跳转,就是编程式导航

​ location.href = ‘’url ‘

​ location.go(number)

​ location.replace(‘url’)

3、vue-router中提供的编程式导航的API

​ (1)this.$router.push(‘url’):将’url’添加到路由表中,增加了一条路由记录

​ (2)this.$router.replace(‘url’):跳转到url中,并替换掉当前的历史记录

​ (3)this.$router.go(number):参数是一个数值,页面跳转到指定的位置

​ (4)this.$router.go()的简化写法:

        ​ A、this.$router.back():后退

        ​ B、this.$router.forword():前进

六、导航守卫

1、用途:在页面导航过程中实现重定向、取消路由、权限验证等业务

2、分类:全局守卫、组件内部守卫、路由独享的守卫

3、全局守卫:

​ (1)全局的前置守卫:使用的router.beforeEach(to,from,next){ }来注册

        ​ to:将要访问的路由的信息对象

        ​ from:将要离开的路由的信息对象

        ​ next:是一个函数,调用next()表示当前路由已经放行

​ (2)next调用的情况:

        ​ A、用户拥有了权限,直接放行:next()

        ​ B、用户没有权限,强制跳转到指定的页面:next(‘/login’)

        ​ C、用户没有权限,不允许访问:next(false)

4、全局前置守卫的使用

​ (1)创建Login.vue组件

​ (2)在路由文件router / index.js中注册全局的前置守卫

你可能感兴趣的:(vue.js,javascript,前端)