$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() 跳转内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue element表格某一列内容过多,超出省略号显示的实现
这篇文章主要介绍了vue element表格某一列内容过多,超出省略号显示的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-01-01
Vue.js基础指令实例讲解(各种数据绑定、表单渲染大总结)
这篇文章主要为大家详细介绍了Vue.js基础指令实例,各种数据绑定、表单渲染大总结,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-07-07


最新评论