美文网首页
vue中$router和$route的区别

vue中$router和$route的区别

作者: 云凡的云凡 | 来源:发表于2020-10-03 09:42 被阅读0次

1、$router对象

router是VueRouter的实例方法,相当于一个全局的路由器对象,作用是进行路由跳转的!就像jQuery里的window.location一样,起到的是导航的作用。里面含有很多属性和子对象,例如history对象,导航到不同url,可以使用this. image.png

路由实例方法:

1、push

// 字符串
   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、go

// 页面路由跳转 前进或者后退
this.$router.go(-1) // 后退

3、replace

 //push方法会向 history 栈添加一个新的记录,而replace方法是替换当前的页面,
 不会向 history 栈添加一个新的记录
// 一般使用replace来做404页面
this.$router.replace('/')

配置路由时path有时候会加 '/' 有时候不加,以'/'开头的会被当作根路径,就不会一直嵌套之前的路径。

二、$route对象

route相当于当前激活的路由对象,包含当前url解析得到当前的路径、参数、query对象等。

image.png

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 当前路径的名字,如果没有使用具名路径,则名字为空。
8、 route.router 路由规则所属的路由器(以及其所属的组件)。 9、 route.meta 路由元信息

route object 出现在多个地方:

组件内的 this.route和 route和route watcher 回调(监测变化处理);
router.match(location) 的返回值
scrollBehavior 方法的参数
导航钩子的参数:

router.beforeEach((to, from, next) => {
 // to 和 from 都是 路由信息对象,后面使用路由的钩子函数就容易理解了
})

所以我们可以通过 route.来获取到路由里的这些信息为自己所用。这就是 route!

相关文章

网友评论

      本文标题:vue中$router和$route的区别

      本文链接:https://www.haomeiwen.com/subject/enyduktx.html