目录
(2)在组件中接收参数:this.$route.params.参数名
(5)在App.vue中通过超链接渲染Books.vue组件
1.查询参数的格式:在URL地址中带参数,例如:'/url地址?参数名1=参数值1&参数名2=参数值2'
2.在组件中接收查询参数:this.$route.query.参数名
1.给指定名称:在使用时如没有给设置名称,默认为default,可以定义多个路由视图,每个路由视图都指定名称
2.在路由表中给路由项添加components属性:将组件渲染到给定名称的视图中
2.编程式导航:通过JavaScript提供的api方法实现页面的跳转,就是编程式导航
(1)this.$router.push('url'):将'url'添加到路由表中,增加了一条路由记录
(2)this.$router.replace('url'):跳转到url中,并替换掉当前的历史记录
(3)this.$router.go(number):参数是一个数值,页面跳转到指定的位置
1.用途:在页面导航过程中实现重定向、取消路由、权限验证等业务
(1)全局的前置守卫:使用router.beforeEach(to,from,next){}来注册
(2)在路由文件router / index.js中注册全局的前置守卫
一.动态路由
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.代表当前正在跳转的路由对象,是一个局部对象
<router-link to="/login/123">登录</router-link>
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中的<router-link>和<router-view>
二.路由中的查询参数
1.查询参数的格式:在URL地址中带参数,例如:'/url地址?参数名1=参数值1&参数名2=参数值2'
2.在组件中接收查询参数:this.$route.query.参数名
3.示例:通过查询参数实现动态路由的效果
(1)修改路由文件:
三.命名路由
1.什么是命名路由?
在路由表中给路由项设置name属性