$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时,你可以通过简单的名称来指定路由,并可以传递参数。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
2022-11-21 css样式文字和数字不在一行,数字会自动换行到下一行