猿记录

一个记录、分享的博客

您的位置:主页 > 技术专栏 > javascript > vue >

vue-router 2.0的一些混淆记录

2017-11-27 10:13:10 作者:yxl 次阅读 vue

学习vue-router 2.0的过程中,有些很容易混淆,现做记录
文章来源网上的大神总结:传送门

$route和$router

1 $route

**路由信息对象:即$router会被注入每个组件中,可以利用它进行一些信息的获取**
**1.$route.path**
字符串,对应当前路由的路径,总是解析为绝对路径,如 "/foo/bar"。
**2.$route.params**
一个 key/value 对象,包含了 动态片段 和 全匹配片段,
如果没有路由参数,就是一个空对象。
**3.$route.query**
一个 key/value 对象,表示 URL 查询参数。
例如,对于路径 /foo?user=1,则有 $route.query.user == 1,
如果没有查询参数,则是个空对象。
**4.$route.hash**
当前路由的 hash 值 (不带 #) ,如果没有 hash 值,则为空字符串。
**5.$route.fullPath**
完成解析后的 URL,包含查询参数和 hash 的完整路径。
**6.$route.matched**
数组,包含当前匹配的路径中所包含的所有片段所对应的配置参数对象。
**7.$route.name    当前路径名字**

2.$router

路由实例即 创建 router 实例,然后传 `routes` 配置
const router = new VueRouter({
  routes // (缩写)相当于 routes: routes
})
**使用:常用于路由的配置
在hmtl页面渲染路由 v-for="(item,index) in $router.options.routes
在routes.js中配置路由**

2.1 全局注册的路由Vue.use(VueRouter)

// 字符串
this.$router.push('home')
// 对象
this.$router.push({ path: 'home' })
// 命名的路由
this.$router.push({ name: 'user', params: { userId: 123 }})
// 带查询参数,变成 /register?plan=123
this.$router.push({ path: 'register', query: { plan: '123' }})

push方法其实和<router-link :to="...">是等同的。
注意:push方法的跳转会向 history 栈添加一个新的记录,当我们点击浏览器的返回按钮时可以看到之前的页面。

2.2 router.replace

 
push方法会向 history 栈添加一个新的记录,而replace方法是替换当前的页面,
不会向 history 栈添加一个新的记录

<router-link to="/05" replace>05</router-link>

凡本站注明“本站”或“投稿”的所有文章,版权均属于本站或投稿人,未经本站授权不得转载、摘编或利用其它方式使用上述作品。

编辑:yxl 关键词: vue-router
0

网友评论