1.router.push(location)=====window.history.pushState
想要导航到不同的 URL,则使用 router.push
方法。这个方法会向 history 栈添加一个新的记录,所以,当用户点击浏览器后退按钮时,则回到之前的 URL。
1
2
3
4
5
6
7
8
9
10
11
|
// 字符串
router.push(
'home'
)
// 对象
router.push({ path:
'home'
})
// 命名的路由
router.push({ name:
'user'
,
params
: { userId: 123 }})
// 带查询参数,变成 /register?plan=private
router.push({ path:
'register'
, query: { plan:
'private'
}})
|
2.router.replace(location)=====window.history.replaceState
跟 router.push
很像,唯一的不同就是,它不会向 history 添加新记录,而是跟它的方法名一样 —— 替换掉当前的 history 记录
3.router.go(n)====window.history.go
1
2
3
4
5
6
7
8
9
10
11
12
|
// 在浏览器记录中前进一步,等同于 history.forward()
router.go(1)
// 后退一步记录,等同于 history.back()
router.go(-1)
// 前进 3 步记录
router.go(3)
// 如果 history 记录不够用,那就默默地失败呗
router.go(-100)
router.go(100)
|