VUE路由router-link和router.push用法
两者的区别
使用router-link方式跳转,会在页面渲染的时候就加载对应的路由比起直接写的方式的优点:不管是h5的history还是hash模式,切换的时候很方便;会默认阻止浏览器的默认事件;写路径的时候不用写基路径了。
$router.push("/myroute")跳转到对应的路径,可在页面中写对应的点击事件,然后执行对应的方法中写跳转,可在跳转前再写一些别的逻辑。
一、<router-link :to="...">
to里的值可以是一个字符串路径,或者一个描述地址的对象。例如:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | // 字符串 <router-link to= "apple" > to apple</router-link> // 对象 <router-link :to= "{path:'apple'}" > to apple</router-link> // 命名路由 <router-link :to= "{name: 'applename'}" > to apple</router-link> //直接路由带查询参数query,地址栏变成 /apple?color=red <router-link :to= "{path: 'apple', query: {color: 'red' }}" > to apple</router-link> // 命名路由带查询参数query,地址栏变成/apple?color=red <router-link :to= "{name: 'applename', query: {color: 'red' }}" > to apple</router-link> //直接路由带路由参数params,params 不生效,如果提供了 path,params 会被忽略 <router-link :to= "{path: 'apple', params: { color: 'red' }}" > to apple</router-link> // 命名路由带路由参数params,地址栏是/apple/red <router-link :to= "{name: 'applename', params: { color: 'red' }}" > to apple</router-link> |
二、router.push(...)方法
同样的规则也适用于router.push(...)方法。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | // 字符串 router.push( 'apple' ) // 对象 router.push({path: 'apple' }) // 命名路由 router.push({name: 'applename' }) //直接路由带查询参数query,地址栏变成 /apple?color=red router.push({path: 'apple' , query: {color: 'red' }}) // 命名路由带查询参数query,地址栏变成/apple?color=red router.push({name: 'applename' , query: {color: 'red' }}) //直接路由带路由参数params,params 不生效,如果提供了 path,params 会被忽略 router.push({path: 'applename' , params:{ color: 'red' }}) // 命名路由带路由参数params,地址栏是/apple/red router.push({name: 'applename' , params:{ color: 'red' }}) |
三、注意点
1、关于带参数的路由总结如下:
无论是直接路由“path" 还是命名路由“name”,带查询参数query,地址栏会变成“/url?查询参数名:查询参数值“;
直接路由“path" 带路由参数params params 不生效;
命名路由“name" 带路由参数params 地址栏保持是“/url/路由参数值”;
2、设置路由map里的path值:
带路由参数params时,路由map里的path应该写成: path:'/apple/:color' ;
带查询参数query时,路由map里的path应该写成: path:'/apple' ;
3、获取参数方法:
在组件中: {{$route.params.color}}
在js里: this.$route.params.color
分类:
91vue.js
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通