Vue Router 参数接收

本文探讨了Vue应用中如何通过query、params和props三种方式传递参数,包括在URL中以'?'符号标识的query参数,以及用于接收动态路由参数的params,以及通过组件间props传递参数的技巧。通过实例展示了在浏览器开发者工具中的观察和如何在组件内部获取这些参数。

query 方式

请求头中是http://localhost:8080/#/demo/news/content?id=3&title=电影这种带有的形式。

:to=" ":表示to属性里边是表达式
query:属性用作传参

        <router-link :to="{
          name:'content',  //
          query :{
            id: n.id,
            title: n.title
          }
        }">
          {{ n.title }}
        </router-link>

在浏览器中的开发者工具中可以看到这里是有参数了
在这里插入图片描述
我们用this.$route.query就可以取对象中的属性了

params 方式

请求头中是http://localhost:8080/#/demo/news/content/1/电影

  • router.js中修改跳转路径
    在这里插入图片描述
  • 接收参数是用params属性
 <router-link :to="{
          name:'content',
          params:{
            id: n.id,
            title: n.title
          }
        }">
          {{ n.title }}
        </router-link>

在浏览器中的开发者工具中可以看到这里是有参数了
在这里插入图片描述
我们用this.$route.params就可以取对象中的属性了

props方式传递

在这里插入图片描述

 // 第一种写法:值为对象,该对象的所有key-value都会以props的形式传给组件
// props:{
 //     id:1,title:'标题'
 // }
//    第二种写法:值为布尔值,当值为true的时候,就会把该组件收到的全部params参数,以props的形式传给该组件
//    但是这种写法并不能解决query的参数接收
//     props:true,
//    第三种写法,值为函数
//     props($route){
//         return {id:$route.query.id,title:$route.query.title}
//         return {id:$route.params.id,title:$route.params.title}
                        //   
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

平平常常一般牛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值