vue中$router和$route的区别

1、$router对象

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

router.back()就会回退之前的url。

vue中$router和$route的区别_第1张图片
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方法其实和是等同的。
push方法的跳转会向 history 栈添加一个新的记录,当我们点击浏览器的返回按钮时可以看到之前的页面。
2、go

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

3、replace

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

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

二、$route对象

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

vue中$router和$route的区别_第2张图片
image.png

1、

route.params
一个 key/value 对象,包含了 动态片段 和 全匹配片段,
如果没有路由参数,就是一个空对象。
3、
route.query.user == 1,
如果没有查询参数,则是个空对象。
4、
route.fullPath
完成解析后的 URL,包含查询参数和 hash 的完整路径。
6、
route.name 当前路径的名字,如果没有使用具名路径,则名字为空。
8、
route.meta 路由元信息

route object 出现在多个地方:

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

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

所以我们可以通过

route!

你可能感兴趣的:(vue中$router和$route的区别)