声明式与编程式
什么是声明式导航与编程式导航?有什么区别?
声明式导航
使用 <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
属性:
replace.go()
该方法的参数是一个整数,指在 history 记录中向前或者后退多少步,类似 window.history.go(n)
。
Last updated