辉太郎看前端(query和params)

前言

queryparams都是一种传参方式,只是有些许不同而已。
在说两者之前,我们首先要知道$router$route的是什么。

$router$route

$router 是路由操作对象,用来操作路由,比如要跳转页面我们就会用到$router
$route 是路由读取对象,用来读取我们路由跳转时携带的参数。

queryparams在路由中的定义
  • query的参数可以在地址栏中拼接,定义时没有也没有关系。
  • params的参数是路由的一部分必须要有,也就是必须定义。
//query传参
{
path:"/路由",
name:"路由",
component:()=>import('组件地址')
},
//params传参
{
path:"/路由/:id",
name:"路由",
component:()=>import('组件地址')
}
  • 在跳转时,也是有一定的区别
  1. 编程式导航

query传参
跳转:this.$router.push('/路由?id=123')
目标组件中接收:this.$route.query.id
params传参
跳转:this.$router.push({name:"路由",params:{id:123456}})
目标组件中接收:this.$route.params.id

  1. 页面导航
//query传参
<router-link :to="'路由?id='+变量">详情</router-link>
//params传参
<router-link :to="路由/:id">详情</router-link>

注:接收和编程式的一样

总结
  • query使用path来引入的,而params是用name来引入的
  • query有点类似get,参数拼接在url地址栏中,在路由中不定义也没有关系;params传参时,参数必须在路由中定义,并且不会显示在url地址栏中。
初出茅庐,请各位大佬多多指教
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值