67、vue $router和$route的区别

一、router为VueRouter的实例,相当于一个全局的路由器对象,里面含有很多属性和子对象,例如history对象。。。经常用的跳转链接就可以用this.$router.push,和router-link跳转一样。。。

this.$router.push会往history栈中添加一个新的记录。。详细见vue官方文档https://router.vuejs.org/zh/guide/essentials/navigation.html

route相当于当前正在跳转的路由对象。。可以从里面获取name,path,params,query等。。

打印this.route和this.router。

路由传参的方式

1.可以手写完整的path:

this.$router.push({path:`/user/${userId}`})

这样传递参数的话,配置路由的时候需要在path上加参数path:user/:userId。

这种接收参数的方式是

this.$route.params.userId。

2.也可以用params传递:


3.也可以用query传递:

query传参是针对path的,params传参是针对name的。。接收参数的方式都差不多。。this.$route.query.this.$route.params.

注意这只是跳转url,跳转到这个url显示什么组件,得配置路由。router跳转和<router-link>标签跳转,规则差不多。

展示上的话:


注意:如果提供了path,params将会被忽略,但是query不属于这种情况。。。

如果使用完整路径和query传参,刷新页面时不会造成路由传参的参数丢失。

这个vue官方文档讲的很详细。

二、有时候配置路由时path有时候会加 '/' 有时候不加,例如path:'name'和path:'/name'。区别其实官方文档说了,我当时没仔细看,导致这个问题还困扰了我很久。
意思就是以 / 开头的会被当做路径,就不会一直嵌套之前的路径。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • SPA单页应用 传统的项目大多使用多页面结构,需要切换内容的时候我们往往会进行单个html文件的跳转,这个时候受网...
    视觉派Pie阅读 14,096评论 1 55
  • github地址,欢迎大家提交更新。 express() express()用来创建一个Express的程序。ex...
    Programmer客栈阅读 7,537评论 0 1
  • 那这次呢?我决定直接就先放一个小小demo上来 其实我们在引入vue-router插件那一刻,我们的网页就已经附带...
    看物看雾阅读 4,286评论 0 1
  • 一直都hin喜欢下雨天 无论淅沥沥的小雨,还是瓢泼的大雨,都喜欢 雨前阴阴凉凉的天气 雨时拍打着雨伞的声音 雨后好...
    茗妹阅读 2,890评论 0 0
  • 今天出差很紧张,跟老大6点多去奋斗。10点回庄。 看时间写本书,让自己更清晰自己坚持的。最近身边一些人 事 物让我...
    曦妮阅读 1,427评论 0 0

友情链接更多精彩内容