vue2路由传参query与params

  1. 传参是this.$router ,接收参数是this.$route ;
  2. this.$router(router 实例) 和 this.$route(当前页面的路由信息)
  3. 注意:$router与$route区别
  4. // $router : 是路由操作对象,只写对象
    // $route : 路由信息对象,只读对象

    1、query传递参数(直接拼接在地址后面,会显示在url后面)

         query传参要用path来引入,params传参要用name来引入,具体看编程式的导航 

//query传参,使用name跳转
this.$router.push({
    name:'second',
    query: {
        queryId:'20210726',
        queryName: 'query'
    }
})

//query传参,使用path跳转
this.$router.push({
    path:'second',
    query: {
        queryId:'20210726',
        queryName: 'query'
    }
})

//query传参接收
this.queryName = this.$route.query.queryName;
this.queryId = this.$route.query.queryId;

2、params传递参数

使用params传参只能使用name进行引入

//params传参 使用name
this.$router.push({
  name:'second',
  params: {
    id:'20210726',
     name: 'query'
  }
})

//params接收参数
this.id = this.$route.params.id ;
this.name = this.$route.params.name ;

//路由

{
path: '/second/:id/:name',
name: 'second',
component: () => import('@/view/second')
}

总结:

  • params是路由的一部分,必须要在路由后面添加参数名。query是拼接在url后面的参数,没有也没关系。
  • params一旦设置在路由,params就是路由的一部分,如果这个路由有params传参,但是在跳转的时候没有传这个参数,会导致跳转失败或者页面会没有内容。

  • 传参可以使用params和query两种方式。
  • 使用params传参只能用name来引入路由,即push里面只能是name:’xxxx’,不能是path:’/xxx’,因为3. params只能用name来引入路由,如果这里写成了path,接收参数页面会是undefined!!!。
  • 使用query传参使用path来引入路由。
  • params是路由的一部分,必须要在路由后面添加参数名。query是拼接在url后面的参数,没有也没关系。
  • 二者还有点区别,直白的来说query相当于get请求,页面跳转的时候,可以在地址栏看到请求参数,而params相当于post请求,参数不会再地址栏中显示
  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Vue3中的路由传参有两种方式:queryparamsquery是通过URL中的查询参数传递参数,例如:/user?id=123&name=张三。在路由配置中,可以使用props属性将query参数映射到组件的props中。 params是通过URL中的路径参数传递参数,例如:/user/123。在路由配置中,需要使用动态路由配置来定义路径参数,例如:/user/:id。在组件中可以通过$route.params来获取路径参数。 需要注意的是,query参数是可选的,而params参数是必须的。另外,query参数可以在URL中直接修改,而params参数只能通过路由跳转来修改。 ### 回答2: Vue.js是一款流行的JavaScript框架之一,它具有易用、高效且灵活的特点。在Vue.js中,路由是非常重要的一个模块,而路由传参就是常见的需求。 Vue3版本中,路由传参主要有两种方式:queryparams。 1. Query传参 Query传参是通过在URL中添加参数,从而将参数传递给目标组件。比如我们要传递一个名称为“name”,值为“user”的参数,可以在路由链接中添加“?name=user”的参数: ```javascript <router-link :to="{ path: '/user', query: { name: 'user' } }">User</router-link> ``` 在目标组件中,我们可以通过$router对象来访问参数: ```javascript this.$route.query.name // user ``` 2. Params传参 Params传参是通过在路由路径中添加参数,从而将参数传递给目标组件。以用户ID为例,我们可以在路由配置中添加“:id”参数: ```javascript { path: '/user/:id', name: 'User', component: User } ``` 在路由链接中,我们可以通过$router对象来设置参数: ```javascript <router-link :to="{ path: '/user/1' }">User 1</router-link> ``` 在目标组件中,我们可以通过$router对象来访问参数: ```javascript this.$route.params.id // 1 ``` 需要注意的是,我们在路由配置中定义的参数名和在路由链接中传递的参数名必须保持一致。另外,Params传参是不支持通过键值对的方式传递多个参数的。 总结 在Vue3中,路由传参有两种方式:queryparamsQuery传参是通过在URL中添加参数,Params传参是通过在路由路径中添加参数。在使用路由传参时,我们需要注意传递参数的方式和参数名的一致性,以确保传参能够正常工作。 ### 回答3: Vue3 是目前全球使用人数最多的前端框架之一,其中路由也是 Vue3 中非常重要的一个部分。在Vue3中,我们可以使用路由传递参数从一个页面到另一个页面。Vue3 路由传参分为两种方式:queryparams。 1. query方式 query方式是通过URL传参的方式将参数进行传递和获取的。在URL后面加上 ?参数名=参数值,可以传递一个或多个参数,多个参数之间使用 & 符号连接。 比如,我们可以这样传递参数: ```javascript <router-link :to="{path:'/user',query:{id:1,name:'Tom'}}">用户</router-link> ``` 在路由中我们可以通过 `$route.query` 获取传递的参数,例如: ```javascript { path: '/user', name: 'user', component: User, query: { id: 1, name: 'Tom' } } ``` 2. params方式 params方式是通过路由路径中的参数将参数进行传递和获取的。使用这种方式传递参数时,参数会变成路由路径的一部分。 比如,我们可以这样传递参数: ```javascript <router-link :to="{ path: '/user/1/Tom' }">用户</router-link> ``` 在路由中我们可以通过 `$route.params` 获取传递的参数,例如: ```javascript { path: '/user/:id/:name', name: 'user', component: User, params: { id: 1, name: 'Tom' } } ``` 总的来说,Vue3 路由传参 queryparams 都有其优劣势。query 参数可以传递任意数量的参数,但是 URL 中传递参数可能会因为长度而受限;params 参数可以在 URL 中优雅地显示要传递的参数,但是只能传递有限的参数,并且参数的顺序也很重要。根据实际情况,我们应该灵活使用不同的方式来进行参数传递。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值