$router.push()中通过path跳转和通过name跳转有什么区别

发布时间 2023-11-21 09:47:18作者: 嘿!那个姑娘

今天在路由跳转传参时发现params传参接收到的总是为空,才发现通过path和name传参是有区别的

  • path传参要完整的路径,不能带参数。name传参可以带params。
  • params的传参页面刷新会丢失,query的传参不会丢失
  1. 使用path进行跳转:

    当你使用path进行跳转时,你需要提供完整的路径字符串,包括路径和查询参数(如果有的话)。例如:

    
      this.$router.push({ path: '/user/123' })
    
    

    使用path进行跳转的优点是路径是静态的,你可以直接指定要跳转到的路径。但是,如果你需要传递参数或查询参数,你需要手动构建完整的路径字符串。

  2. 使用name进行跳转:

    当你使用name进行跳转时,你只需要提供路由的名称,而不需要手动构建路径字符串。Vue Router会自动解析并找到对应的路径。例如:

      this.$router.push({ name: 'User' });
    

    使用name进行跳转的优点是你可以通过简单的名称来指定要跳转到的路由,而不需要手动构建路径字符串。同时,Vue Router会自动解析并找到对应的路径。此外,当使用命名路由时,你还可以传递参数,例如:

      this.$router.push({ name: 'User', params: { userId: 123 } });
    

    这样,Vue Router会自动将userId参数填充到路径中。

    总而言之,使用path和name进行跳转的主要区别在于:使用path时,你需要手动构建完整的路径字符串;而使用name时,你可以通过简单的名称来指定路由,并可以传递参数。