Vue路由传递query参数两种方式

 更新时间:2023年06月05日 08:37:39   作者:小花皮猪  
路由是可以传递参数的,一般使用query进行传参,有两种方式,本温酒通过代码示例给大家介绍这两种传递方式,感兴趣的小伙伴可以参考阅读

路由传递query参数两种方式

路由是可以传递参数的,一般使用query进行传参,有两种方式,接下来一一展示

1 案例展示

先编写一个简单的案例

我这里用的一个三级路由

这里使用三级路由以及展示路由视图

这样点击就跳转对应的路径了,接下来进行路由跳转的时候传参即可

2 路由传参

路由可以传递两种参数形式,一种是query字符串形式参数,一种是对象形式参数,下面进行说明

方式1:字符串传参(不推荐)

参数和ajax或axios发送的query参数几乎一致,写法基本和和ajax一致,都是 url?key=value&拼接参数的格式,例如:

<router-link to="/home/message/detail?id=1&title=你好">

路径上也会有所体现

传递完的参数就到$route的query里面,这里我在组件挂载的时候输出了一个vc实例

可以在$route的query里面找到参数

接收路由参数

想要接收使用参数,也直接从$route的query里面获取即可

但是现在参数是死的,所以需要从表达式里面传递

表达式错误传参

注意,在使用到表达式传参的场景时,切不可使用下面两种传递方式

这样就会直接当前字符串解析

也不可以直接使用:to的方式,这样会解析成一个表达式,无法识别报错

表达式正确传参

正确的做法应该是加上``并且使用$进行拼接传递

<!-- 跳转路由并携带query参数 to的字符串写法 -->
   <router-link :to="`/home/message/detail?id=${msg.id}&title=${msg.title}`">{{msg.title}}</router-link>  

接收参数还是从$route的query里面获取,这样就可以完成使用query方式参数

但是query这种拼接方式有些复杂,所以有了第二种传参方式,使用对象传参

方式2:对象传参(推荐)

对象方式进行传参,既然现在to是一个对象,那么有几个属性可以使用

path:想去哪里跳转

query:它是一个对象,在对象里面配置参数

 <!-- 跳转路由并携带query参数 to的对象写法 -->
 <router-link :to="{
         path:'/home/message/detail',
          query:{id:msg.id,title:msg.title}
 }">

这种写法清晰明了,推荐使用

3 总结

1 传递参数

<!-- 跳转并携带query参数,to的字符串写法 -->
<router-link :to="/home/message/detail?id=666&title=你好">跳转</router-link>
<!-- 跳转并携带query参数,to的对象写法 -->
<router-link 
        :to="{
                path:'/home/message/detail',
                query:{
                   id:666,
            title:'你好'
                }
        }"
>跳转</router-link>

2 接收参数

$route.query.id
$route.query.title

以上就是Vue路由传递query参数两种方式的详细内容,更多关于Vue路由传递query的资料请关注脚本之家其它相关文章!

相关文章

  • element-ui滚动条el-scrollbar置底方式

    element-ui滚动条el-scrollbar置底方式

    这篇文章主要介绍了element-ui滚动条el-scrollbar置底方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • vue3中setup声明变量的方式汇总

    vue3中setup声明变量的方式汇总

    本文给大家介绍Vue3中setup()函数中声明变量的几种方法,希望本文能够帮助你更好地理解Vue3的开发方式,感兴趣的朋友跟随小编一起看看吧
    2023-11-11
  • Vue中的组件及路由使用实例代码详解

    Vue中的组件及路由使用实例代码详解

    组件系统是 Vue 的一个重要概念,因为它是一种抽象,允许我们使用小型、独立和通常可复用的组件构建大型应用。这篇文章主要介绍了Vue中的组件及路由使用 ,需要的朋友可以参考下
    2019-05-05
  • 前端文件导出设置responseType为blob时遇到的问题及解决

    前端文件导出设置responseType为blob时遇到的问题及解决

    这篇文章主要给大家介绍了关于前端文件导出设置responseType为blob时遇到的问题及解决方法,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • 解决iview多表头动态更改列元素发生的错误的方法

    解决iview多表头动态更改列元素发生的错误的方法

    这篇文章主要介绍了解决iview多表头动态更改列元素发生的错误的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • Vue完整项目构建(进阶篇)

    Vue完整项目构建(进阶篇)

    这篇文章主要介绍了Vue完整项目构建(进阶篇)的相关资料,需要的朋友可以参考下
    2018-02-02
  • vue中的axios配置及接口请求路径api配置

    vue中的axios配置及接口请求路径api配置

    这篇文章主要介绍了vue中的axios配置及接口请求路径api配置方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • element-ui form表单的动态rules校验功能实现

    element-ui form表单的动态rules校验功能实现

    在vue项目中,有时候可能会用到element-ui form表单的动态rules校验,这篇文章主要介绍了element-ui form表单的动态rules校验,我们可以巧妙的运用element-ui form表单里面form-item的校验规则来处理,本文结合实例代码介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • Vue组件公用方法提取mixin实现

    Vue组件公用方法提取mixin实现

    这篇文章主要介绍了Vue组件公用方法提取mixin实现,多个组件共用一个方法时可以用 mixin 抽取到一个js文件中,作为共用方法,下面一起进入文章了解更多详细内容吧
    2022-03-03
  • 在vue中使用vue-echarts-v3的实例代码

    在vue中使用vue-echarts-v3的实例代码

    这篇文章主要介绍了在vue中使用vue-echarts-v3的实例代码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09

最新评论