1、$router对象
router是VueRouter的实例方法,相当于一个全局的路由器对象,作用是进行路由跳转的!就像jQuery里的window.location一样,起到的是导航的作用。里面含有很多属性和子对象,例如history对象,导航到不同url,可以使用this.
image.png
1、push push方法其实和<router-link :to="...">是等同的。 3、replace 配置路由时path有时候会加 '/' 有时候不加,以'/'开头的会被当作根路径,就不会一直嵌套之前的路径。 route相当于当前激活的路由对象,包含当前url解析得到当前的路径、参数、query对象等。 1、
route.params route object 出现在多个地方: 组件内的 this.route和 route和route watcher 回调(监测变化处理); 所以我们可以通过
route!路由实例方法:
// 字符串
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方法的跳转会向 history 栈添加一个新的记录,当我们点击浏览器的返回按钮时可以看到之前的页面。
2、go// 页面路由跳转 前进或者后退
this.$router.go(-1) // 后退
//push方法会向 history 栈添加一个新的记录,而replace方法是替换当前的页面,
不会向 history 栈添加一个新的记录
// 一般使用replace来做404页面
this.$router.replace('/')
二、$route对象
一个 key/value 对象,包含了 动态片段 和 全匹配片段,
如果没有路由参数,就是一个空对象。
3、
route.query.user == 1,
如果没有查询参数,则是个空对象。
4、
route.fullPath
完成解析后的 URL,包含查询参数和 hash 的完整路径。
6、
route.name 当前路径的名字,如果没有使用具名路径,则名字为空。
8、
route.meta 路由元信息
router.match(location) 的返回值
scrollBehavior 方法的参数
导航钩子的参数:router.beforeEach((to, from, next) => {
// to 和 from 都是 路由信息对象,后面使用路由的钩子函数就容易理解了
})
网友评论