$router.push()中通过path跳转和通过name跳转区别解析
作者:嘿!那个姑娘
今天在路由跳转传参时发现params传参接收到的总是为空,才发现通过path和name传参是有区别的,这篇文章主要介绍了$router.push()中通过path跳转和通过name跳转有什么区别,需要的朋友可以参考下
今天在路由跳转传参时发现params传参接收到的总是为空,才发现通过path和name传参是有区别的
- path传参要完整的路径,不能带参数。name传参可以带params。
- params的传参页面刷新会丢失,query的传参不会丢失
使用path进行跳转:
当你使用path进行跳转时,你需要提供完整的路径字符串,包括路径和查询参数(如果有的话)。例如:
this.$router.push({ path: '/user/123' })
使用path进行跳转的优点是路径是静态的,你可以直接指定要跳转到的路径。但是,如果你需要传递参数或查询参数,你需要手动构建完整的路径字符串。
使用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时,你可以通过简单的名称来指定路由,并可以传递参数。
到此这篇关于$router.push()中通过path跳转和通过name跳转有什么区别的文章就介绍到这了,更多相关$router.push() 跳转内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!