声明式与编程式
什么是声明式导航与编程式导航?有什么区别?
声明式导航
使用 <router-link></router-link> 创建 a 标签来定义导航链接的称为声明式导航,to 显示的指明了导航的目的地。
编程式导航
编程式导航,顾名思义,就是通过代码来进行路由的跳转。想要导航到不同的 URL,可使用 router.push 方法。在 Vue 实例内部,你可以通过 $router 访问路由实例,因此使用 $router.push('/foo') 进行路由的跳转与以下声明式跳转等效:
<!-- 点击后将在内部执行 router.push('/foo') -->
<router-link to="/foo"></router-link>该方法的参数可以是一个字符串路径,或者一个描述地址的对象。例如:
// 字符串
router.push('home')
// 对象
router.push({ path: 'home' })
// 命名的路由
router.push({ name: 'user', params: { id: 123 }})
// 带查询参数,变成 /register?plan=private
router.push({ path: 'register', query: { plan: 'private' }})常用的 API
router.push()
函数签名:
router.push(location, onComplete?, onAbort?)// onComplete 与 onAbort 可选这个方法会向 history 栈添加一个新的记录,当用户点击浏览器后退按钮时,则回到之前的 URL。
router.replace()
函数签名:
router.replace(location, onComplete?, onAbort?)// onComplete 与 onAbort 可选跟 router.push 很像,唯一的不同就是,它不会向 history 添加新记录,而是跟它的方法名一样,替换掉当前的 history 记录。
如果在命令式导航使用 replace,你应该在 router-link 组件上添加 replace 属性:
<!-- 点击后将在内部执行 router.replace('/foo') -->
<router-link to="/foo" replace></router-link>replace.go()
该方法的参数是一个整数,指在 history 记录中向前或者后退多少步,类似 window.history.go(n)。
// 在浏览器记录中前进一步,等同于 window.history.forward()
router.go(1)
// 后退一步记录,等同于 window.history.back()
router.go(-1)Last updated