# vue router 如何使用params query传参,以及有什么区别
## 写在前面:
传参是前端经常需要用的一个操作,很多场景都会需要用到上个页面的参数,本文将会详细介绍vue router 是如何进行传参的,以及一些小细节问题。有需要的朋友可以做一下参考,喜欢的可以点波赞,或者关注一下,希望可以帮到大家。
> 本文首发于个人blog:[OBKoro1's]([http://obkoro1.com/](http://obkoro1.com/))
## Vue router如何传参
### params、query是什么?
params:/router1/:id ,/router1/123,/router1/789 ,**这里的id叫做params**
query:/router1?id=123 ,/router1?id=456 ,这里的id叫做query。
### 路由界面:
router.js:
路由设置这里,**当你使用params方法传参的时候,要在路由后面加参数名,**并且传参的时候,参数名要跟路由后面设置的参数名对应。使用query方法,就没有这种限制,直接在跳转里面用就可以。
![](https://box.kancloud.cn/e773e7e726b517524fe17e3577d0a26c_2038x1190.png)
**注意:**如果路由上面不写参数,也是可以传过去的,但不会在url上面显示出你的参数,并且当你跳到别的页面或者刷新页面的时候**参数会丢失**(如下图所示),那依赖这个参数的http请求或者其他操作就会失败。
![](https://box.kancloud.cn/6e9a956de59c85fe3fe3406393a76ac7_1190x794.png)
步骤1、点击跳转
![](https://box.kancloud.cn/e64fa452b9df92f4e9f3f9e94df4d24c_1218x800.png)
步骤2、刷新页面
![](https://box.kancloud.cn/809007c7aae4261de590ee110125decd_1202x786.png)
注意看上面的路由参数,id这个参数是我们有设置在路由上面的,id2我没有设置在路由里面,所以刷新之后id2就不见了,在项目中,我们总不可能要求用户不能刷新吧。
### 组件1:
~~~
<template>
<div class="app_page">
<h1>从这个路由传参到别的路由</h1>
<router-link :to="{ name:'router1',params: { id: status ,id2: status3},query: { queryId: status2 }}" >
router-link跳转router1
</router-link>
</div>
</template>
<script>
export default {
name: 'app_page',
data () {
return {
status:110,
status2:120,
status3:119
}
},
}
</script>
~~~
### 编程式导航跳转:
上面的router-link传参,也可以使用[router文档](https://link.juejin.im/?target=https%3A%2F%2Frouter.vuejs.org%2Fzh-cn%2Fessentials%2Fnavigation.html)里面的编程式导航来跳转传参。
~~~
this.$router.push({ name:'router1',params: { id: status ,id2: status3},query: { queryId: status2 }});
//编程跳转写在一个函数里面,通过click等方法来触发
~~~
**这两种传参效果是一模一样的,编程式导航,可以用来做判断跳转,比如是否授权,是否登录,等等状态**,对此不太了解的小伙伴们,可以跳过这个编程式导航,以后再来看。
### 组件2:
~~~
<template>
<div class="router1">
<h1>接收参数的路由</h1>
<h1> params.id:{{ $route.params }}</h1>
<h1>query.status:{{ $route.query.queryId }}</h1>
<keep-alive>
<router-view></router-view>
</keep-alive>
</div>
</template>
~~~
传参还是比较简单的,按着上面组件的使用方法就可以成功传过去了。
**提示:**获取路由上面的参数,用的是$route,后面没有r。
### params传参和query传参有什么区别:
![](https://box.kancloud.cn/c8b5d8f9a74e79728eacf11e01cdb082_1158x1002.png)
1、params是路由的一部分,必须要有。query是拼接在url后面的参数,没有也没关系。
**params一旦设置在路由,params就是路由的一部分**,如果这个路由有params传参,但是在跳转的时候没有传这个参数,会导致跳转失败或者页面会没有内容。
比如:跳转/router1/:id
~~~
<router-link :to="{ name:'router1',params: { id: status}}" >正确</router-link>
<router-link :to="{ name:'router1',params: { id2: status}}">错误</router-link>
~~~
2、params、query不设置也可以传参,但是params不设置的时候,刷新页面或者返回参数会丢失,query并不会出现这种情况,这一点的在上面说过了
## **后话:**
本文到这里就结束了,写的不好的地方,请各位大佬们见谅。
- 前言
- 写在前言
- 一些开发遇到的问题
- H5标签中的属性控制
- el-table的每个对象的属性值
- el-form多个表单同时验证必填项
- el-table 修改表头
- el-input的多种验证
- vue键盘回车事件
- blob导出
- table中selectable( 是否勾选)
- 手动更新视图
- 日期选择器,自定义可选范围
- select 自定义搜索
- 监听回车事件
- 表格初始化不可勾选
- el-input输入限制
- table时间格式转换
- table自适应高度
- JS问题记录
- js字符数组转换为数字数组
- js防抖和节流
- JS电脑是否有网判断
- JS属性记录
- 遍历方法(12个)
- 改变原数组(9个)
- 不改变原数组(8个)
- JS数组、字符串常用方法
- 遍历对象
- Vue
- vue-router
- vue-router 如何在新窗口打开页面
- vue-router 之 keep-alive缓存篇
- keep-alive项目案例
- 路由知识点归纳总结
- params、query传参
- vue问题记录
- vuejs npm chromedriver 报错
- vuex
- vuex个人理解
- Vuex的简单实例应用