路由params、query传参及区别

简介: 功能

Vue路由如何使用params query传参,以及有什么区别

一、params、query是什么?

params:/router1/:id ,/router1/123,/router1/789 ,这里的id叫做params

query:/router1?id=123 ,/router1?id=456 ,这里的id叫做query

二、路由(router.js)

路由设置这里,当你使用params方法传参的时候,要在路由后面加参数名,并且传参的时候,参数名要跟路由后面设置的参数名对应。使用query方法,就没有这种限制,直接在跳转里面用就可以。
在这里插入图片描述

注意:如果路由上面不写参数,也是可以传过去的,但不会在url上面显示出你的参数,并且当你跳到别的页面或者刷新页面的时候 参数会丢失,那依赖这个参数的http请求或者其他操作就会失败。

三、案例:

组件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>
AI 代码解读

上面的router-link传参,也可以使用router文档里面的编程式导航来跳转传参。

this.$router.push({  name:'router1',params: { id: status ,id2: status3},query: { queryId:  status2 }});
    //编程跳转写在一个函数里面,通过click等方法来触发
AI 代码解读
这两种传参效果是一模一样的,编程式导航,可以用来做判断跳转,比如是否授权,是否登录,等等状态

组件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>
AI 代码解读
提示:获取路由上面的参数,用的是$route,后面没有r。

总结:params传参和query传参区别

1、地址栏中区别:

​ query传参:出现”
​ param传参:出现”/

2、获取参数方式区别:
query传参:this.$route.query
params传参:this.$route.params

3、params设置在路由上,成为路由的一部分,否则刷新页面时params会丢失。query是拼接在url后面的参数,没有也没关系。

e.params`

3、params设置在路由上,成为路由的一部分,否则刷新页面时params会丢失。query是拼接在url后面的参数,没有也没关系。

目录
相关文章
在vue中,直接给一个数组项赋值,Vue 能检测到变化吗?
在vue中,直接给一个数组项赋值,Vue 能检测到变化吗?
384 1
Qt QSet 详解:从底层原理到高级用法
Qt QSet 详解:从底层原理到高级用法
1075 0
uni-app监听页面滚动
uni-app监听页面滚动
694 0
Vue3 复制 copy 功能实现(vue-clipboard3)
Vue3 复制 copy 功能实现(vue-clipboard3)
1692 0
vue路由导航守卫(全局守卫、路由独享守卫、组件内守卫)
vue路由导航守卫(全局守卫、路由独享守卫、组件内守卫)
471 0
NAS深度解析:面向云原生应用的文件存储
本文深入解析了面向云原生应用的文件存储NAS,由阿里云专家分享。内容涵盖Cloud Native与AI浪潮下的技术创新,包括高性能、弹性伸缩、成本优化及数据安全等方面。针对云原生应用的特点,NAS在Serverless生态中不断演进,提供多种产品规格以满足不同需求,如极速型NAS、归档存储等,确保用户在高并发场景下获得稳定低延时的存储体验。同时,通过优化挂载参数和容器访问策略,提升整体性能与可用性。
252 11
vue3【实用教程】声明响应式状态(含ref,reactive,toRef(),toRefs() 等)
vue3【实用教程】声明响应式状态(含ref,reactive,toRef(),toRefs() 等)
244 0
如何在Vue页面中引入img下的图片作为背景图。../的使用
这篇文章介绍了在Vue页面中如何引入`img`目录下的图片作为背景图,提供了两种使用相对路径的方法。第一种是使用`../assets/img/`作为路径引入图片,第二种是使用`../../assets/img/`作为路径。文章还展示了使用这些方法的代码实现和效果展示,并鼓励读者学无止境。
如何在Vue页面中引入img下的图片作为背景图。../的使用
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问