vue 中 $route 和 $router 的区别

this.$router是 router 实例
通过 this.$router 访问路由器,相当于获取了整个路由文件,在$router.option.routes中,可以查看到当前项目的整个路由结构 具有实例方法
1
// 导航守卫
router.beforeEach((to, from, next) => {
/* 必须调用 next /
})
router.beforeResolve((to, from, next) => {
/ 必须调用 next */
})
router.afterEach((to, from) => {})

// 动态导航到新路由
router.push
router.replace
router.go
router.back
router.forward

this.$route
通过 this.$route 访问的是当前激活的路由,获取和当前路由有关的信息,这个属性是只读的,里面的属性是不可变的,不过可以 watch 监测。
1
fullPath: “” // 当前路由完整路径,包含查询参数和 hash 的完整路径
hash: “” // 当前路由的 hash 值 (锚点)
matched: [] // 包含当前路由的所有嵌套路径片段的路由记录
meta: {} // 路由文件中自赋值的meta信息
name: “” // 路由名称
params: {} // 一个 key/value 对象,包含了动态片段和全匹配片段就是一个空对象。
path: “” // 字符串,对应当前路由的路径
query: {} // 一个 key/value 对象,表示 URL 查询参数。跟随在路径后用’?'带参数

你可能感兴趣的:(vue.js,前端,javascript)