Auth: 王海飞
Data:2019-02-22
Email:779598160@qq.com
github:https://github.com/coco369/knowledge
路由中有三个基本的概念: route, routes, router
1)route : 指一条路由。
2)routes : 指一组路由,将route定义的每一条路由组合起来,形成一个数组。
3)router : 是一个机制,相当于一个管理者,用于管理路由。由于routes只是定义了一组路由,而router用于管理路由。当请求来了,router这是将发挥作用,其回去routes中查找定义的route路由,如果找到定义的路由,则调用相关的组件,返回对应的内容。
vue-router中的路由也是基于route、routes、route来实现的
在vue中实现路由还是相对简单的。因为我们页面中所有内容都是组件化的,我们只要把路径和组件对应起来就可以了,然后在页面中把组件渲染出来。
1)页面实现(html模版中)
在vue-router中, 我们看到它定义了两个标签
2)main.js 中配置路由概念
首先要定义route, 一条路由的实现。它是一个对象,由两个部分组成: path和component. path 指路径,component 指的是组件。如:{path:’/home’, component: home}
3) 配置,组成一个routes:
var routes = [
{ path: '/home', component: Home },
{ path: '/about', component: About }
]
4)创建router 对路由进行管理,它是由构造函数 new vueRouter() 创建,接受routes 参数。
var router = new VueRouter({
routes // routes: routes 的简写
})
5)配置完成后,把router 实例注入到 vue 根实例中,就可以使用路由了
var app = new Vue({
router
}).$mount('#app')
执行过程:当用户点击 router-link 标签时,会去寻找它的 to 属性, 它的 to 属性和 js 中配置的路径{ path: '/home', component: Home} path 一一对应,从而找到了匹配的组件, 最后把组件渲染到