Vue-router动态路由配置

例如我们有一个 User 组件,对于所有 ID 各不相同的用户,都要使用这个组件来渲染。那么,我们可以在 vue-router 的路由路径中使用『动态路径参数』(dynamic segment)来达到这个效果:

const User = {
  template: 'User' }
const router = new VueRouter({
  routes: [
   动态路径参数 以冒号开头
    { path: '/user/:id', component: User }
  ]
})
现在呢,像 /user/foo 和 /user/bar 都将映射到相同的路由。
一个『路径参数』使用冒号 : 标记。当匹配到一个路由时,参数值会被设置到 this.$route.params,可以在每个组件内使用。于是,我们可以更新 User 的模板,输出当前用户的 ID:
const User = {
  template: 'User {{ $route.params.id }}' }

当使用路由参数时,两个路由都复用同个组件,比起销毁再创建,复用则显得更加高效。也意味着组件的生命周期钩子不会再被调用。 想对路由参数的变化作出响应的话,你可以简单地 watch(监测变化) $route 对象:

const User = {
  template: '...',
  watch: { '$route' (to, from) {
      // 对路由变化作出响应...
    }
  }
}

或者使用 2.2 中引入的 beforeRouteUpdate 守卫:

const User = {
  template: '...',
  beforeRouteUpdate (to, from, next) {
    // react to route changes...
    // don't forget to call next()
  }
}
全部评论

相关推荐

如题,我是双非一本,感觉前端主要的技术学的差不多了,也做过一点小项目练手。来点大神锐评一下我的简历,开学去海投了。
牧渊0320:自我评价挪到后面 然后项目经历可以适当提前,最好是两个以上为佳 另外v3对应的是element-plus element-ui是v2的 虽然都懂意思 但是最好还是严谨点 另外可以包装一些比较有含金量的场景,像大文件上传 sse 并发控制 这些难点尽量试着缝一下,再不济最基础的权限控制总得有吧
点赞 评论 收藏
分享
2024-11-28 21:33
广东工业大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务