vue router.push(),router.replace(),router.go()

vue router.push(),router.replace(),router.go()

2017-07-27 15:23 by 改个名字吧, 13585 阅读, 0 评论, 收藏编辑

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)

猜你喜欢

转载自blog.csdn.net/a13330069275/article/details/81010785