声明式与编程式
什么是声明式导航与编程式导航?有什么区别?
声明式导航
使用 <router-link></router-link>
创建 a
标签来定义导航链接的称为声明式导航,to
显示的指明了导航的目的地。
编程式导航
编程式导航,顾名思义,就是通过代码来进行路由的跳转。想要导航到不同的 URL,可使用 router.push
方法。在 Vue 实例内部,你可以通过 $router
访问路由实例,因此使用 $router.push('/foo')
进行路由的跳转与以下声明式跳转等效:
该方法的参数可以是一个字符串路径,或者一个描述地址的对象。例如:
常用的 API
router.push()
函数签名:
这个方法会向 history 栈添加一个新的记录,当用户点击浏览器后退按钮时,则回到之前的 URL。
router.replace()
函数签名:
跟 router.push
很像,唯一的不同就是,它不会向 history 添加新记录,而是跟它的方法名一样,替换掉当前的 history 记录。
如果在命令式导航使用 replace
,你应该在 router-link
组件上添加 replace
属性:
在 router.push
和 router.replace
中提供了 onComplete
和 onAbort
两个可选的回调函数。onComplete 将会在导航成功 (在所有的异步钩子被解析之后), onAbort 将会在导航终止 (导航到相同的路由、或在当前导航完成之前导航到另一个不同的路由) 的时候进行相应的调用。
如果目的路由和当前路由相同,只有参数发生了改变 (比如从一个用户资料到另一个 /users/1
-> /users/2
),你需要使用 beforeRouteUpdate
守卫来监听/捕获/响应这个变化(例如获取用户信息),这一点在动态路由匹配一节有所提及。
replace.go()
该方法的参数是一个整数,指在 history 记录中向前或者后退多少步,类似 window.history.go(n)
。
router.push
、 router.replace
和 router.go
跟 window.history.pushState
、 window.history.replaceState
和 window.history.go
好像, 实际上它们确实是效仿了window.history
的 API,这使得在 Vue Router 中操作 history 变得简单。 此外,Vue Router 的导航方法 (push
、replace
、go
) 在各类路由模式 (history
、 hash
和 abstract
) 下表现一致。
Last updated