下面整理根据官方文档以及自我理解整理,如有不足,请指教。
下面是来自一段官方的原话。
Vue Router 是 Vue.js 官方的路由管理器。它和 Vue.js 的核心深度集成,让构建单页面应用变得易如反掌。包含的功能有:
来一个简单的栗子
1 js 2 // 引入vue 3 // 引入vue-router, 假如是模块化编程,需要Vue.use(VueRouter)来使用插件 4 5 // 1、引入组件,定义也可 6 import Bar from ‘./Bar‘ 7 8 9 10 11 // 2、定义路由 12 const routes = [ 13 {path: ‘/bar‘, component:Bar} 14 ] 15 16 // 3、创建一个router实例,然后传入routes 17 18 const router = new VueRouter({ 19 router 20 }) 21 22 // 4、创建跟实例并挂载 23 cosnt app = new Vue({ 24 router 25 }).$mount(‘#app‘)
这样一个简单的路由就实现了,可以在vue的根实例就来访问路由。比如:this.$router,this.$route
this.$router: 表示用来访问路由器
this.$route: 表示当前路由
比如:this.$router.go(-1) 用来后退一步,而this.$route.params查看当前路由url的参数
这里的this.$router和上诉代码的router实例其实是一致的,如:也可以直接使用上面的router实例来进行操作,当然这样的话,就需要在每一个需要使用路由的地方来引入路由,这样的话略显麻烦。所以还是采取使用this.$router来使用的比较方便。
另一个概念:视图
视图:路由匹配到的组件讲渲染到改视图处,这往往很有用,比如将一个页面切分成很多区域,实际路由实际去刷新那一部分区域即可。
1 <div class="app"> 2 <p> 3 <!-- 使用 router-link 组件来导航. --> 4 <!-- 通过传入 `to` 属性指定链接. --> 5 <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 --> 6 <router-link to="/bar">Go to Bar</router-link> 7 </p> 8 <!-- 路由出口 --> 9 <!-- 路由匹配到的组件将渲染在这里 --> 10 <router-view></router-view> 11 </div>
动态路由:上面的路由都是写死的,比如/bar,但实际业务可能不止这样,所以可以使用动态路由来进行匹配
1 const City = { 2 template: ‘<div>城市名字: {{$route.params.cityname}}</div>‘ 3 } 4 5 const router = new VueRouter({ 6 routes: [ 7 // 动态路由的参数,由冒号开头表示 8 { path: ‘/city/:cityname‘, component: City} 9 ] 10 }) 11 12 // 这样,当路由访问到/city/广州,这样模板中,就会渲染出城市的名字,所以可以用$route.params来获取动态参数。
动态路由是可以嵌套的。
如:/city/:cityname/select/:select_id, 这里就有两个动态路由了。对应的cityname和select_id的值都会设置到$route.params中。
通配符匹配:可以使用*来匹配任意路径,这往往是有用的,毕竟谁也不想用户直接看到404状态码。
1 { 2 // 这样会匹配所有的路径 3 path: ‘*‘ 4 } 5 6 // 通配符的位置需要放置路由的最后。 7 // 这里因为路由匹配的规则是根据路由定义的先后来跳转的 8 9 // 所以下面这种是错误的,会一直匹配到* 10 cosnt error = { 11 template: ‘<div>嘿,这里不是你该来的</div>‘ 12 } 13 14 const routes = [ 15 { 16 path: ‘*’, 17 component: error 18 }, 19 { 20 // 正常路由 21 path: ‘/city‘, 22 component: xxx 23 } 24 ] 25
所有为了避免这种情况,还是把通配符放最后吧。
1 // 这样就正常了 2 const routes = [ 3 { 4 // 正常路由 5 path: ‘/city‘, 6 component: xxx 7 }, 8 { 9 path: ‘*’, 10 component: error 11 } 12 ]
这里就关于路由的匹配优先级的问题,路由的优先级是根据定义的顺序来排的
在使用通配符的时候,$route.params会自动添加一个pathMatch的参数,包含着URL通过通配符的部分。
1 // 如果按照上诉的路由 2 this.$router.push(/cityname) // 由于没有该路由,所以匹配通配符 3 this.$route.params.pathMatch // ’cityname‘
嵌套路由:嵌套路由属于经常通用的情况,毕竟/aaa显示一个组件,/aaa/bbb显示是另一个组件,所以嵌套来使路由便于管理
1 const router = new VueRouter({ 2 routes: [ 3 { path: /city/:id, component: City, 4 children: [{ 5 // 当路由进入 /city/:id/post 匹配成功 6 // 注意这里不能写/post,这样会直接匹配到根路由,也就失去了嵌套路由的意义 7 path: ‘post‘, 8 component;CityPost 9 }] 10 } 11 ] 12 }) 13 14 // 嵌套路由使用children作为子级的路由,这样可以嵌套多层路由,子子孙孙孙孙孙无穷尽
编程式内容:
导航路由的时候,我们可以使用<router-link :to="xxx">来渲染成a标签来进行导航,可以使用this.$router的方法进行导航。
router的方法是效仿 window.history的api
router.push(location, onComplete, onAbort)
--location(路由地址)是必选的,其他两个是回调方法,在新版本中,会直接返回一个promise,直接.then来进行回调就可
// 推入路由来显示,vue-router的路由模式应该是根据栈来设计的(不知道,瞎讲的,没看过源码)
// 打脸了,还真是栈,不过是history栈,这个方法会向history栈,推入一条记录。
所以<router-link :to=“xxx”>和router.push(“xxx”) 是一样的。
--location: 这个参数可以是一个字符串路径,也可以是一个对象
1 // 字符串 2 router.push(’city‘) 3 4 // 对象 5 router.push({path: ‘ciry‘}) 6 7 // 命名路由, 相当于给路由定义一个名字,需要在路由那边使用name来定义 8 router.push({name: ‘user‘, params: {userId: ‘123‘}}) 9 // 这里为什么使用path呢,由于使用path的话,params会被忽略掉,因为参数本来就是路径的一部分,所以要写满带参数的路径 10 // 如: 11 router.push({ path: `/user/${userId}` }) 12 13 14 15 // 带查询参数,变成 /register?plan=private 16 router.push({ path: ‘register‘, query: { plan: ‘private‘ }})
router.replace(location, oncomplete, onAbort)
参数上同,不同点,在于不会像history添加新纪录,而是替换掉
<router-link :to="" replace> // 声明式
router.go(n)
--n是一个整数,用来表示在history中前进或者后退几步,和window.history.go(n)原理,超出记录的长度则失败
命名路由:通过来个路由起一个别名来进行访问
1 // 上诉代码块中,使用名字,是需要像下面这样使用name来定义就可 2 const router = new VueRouter({ 3 routes: [ 4 { 5 path: ‘/user/:userId‘, 6 name: ‘user‘, 7 component: User 8 } 9 ] 10 })
命令视图:视图时路由的出口,组件渲染在这里,但是视图可以有多个,来渲染多个组件.
router-view中使用name属性来定义,默认不填为default
路由配置时,使用components来配置(需要添加s)
1 const router = new VueRouter({ 2 routes: [ 3 { 4 path: ‘/‘, 5 components: { 6 default: Foo, 7 a: Bar, 8 b: Baz 9 } 10 } 11 ] 12 })
重定向:重新定位到另一个位置,在路由配置中使用redirect:‘路径xxx‘来声明
原文:https://www.cnblogs.com/lsAxy/p/12752175.html