vue路由传参接收以及传参对象为对象时的问题及解决

 更新时间:2022年09月02日 16:31:21   作者:小刘加油!  
这篇文章主要介绍了vue路由传参接收以及传参对象为对象时的问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

路由传参接收以及传参对象为对象时的问题

具体代码如下所示:

场景

<div @click='toDetail'>查看详情</div>

路由传参不能直接传一个对象,需要使用JSON.stringify()方法将其转换成一个字符串,然后在其他页面接受的时候再使用JSON.parse()方法转换成一个对象

const router = useRouter()
const toDetail = () => {
    // 我使用的是Vue3,router要从useRouter获取
    router.push({ name: 'viewAttendPerson', params: { list: JSON.stringify(formObj.form.myMeetingParticipatorList) } })
}

接收路由参数

1. Vue3接收

import { useRoute } from "vue-router";
setup() {
    const route = useRoute()
    const data = JSON.parse(route.params.list)
}

2. Vue2接收

let data = this.$route.params.list
data = JSON.parse(data)

vue路由传参总结

Vue路由传参

1.route-link路由导航

在to跳转链接后传递参数,获取时需要在路由配置path时注明,才能通过$route.params拿到

<router-link to="/a/123">routerlink传参</router-link>
 
// 跳转后拿到参数
mounted () {
  this.num = this.$route.params.num
}
 
 
//num是在配置路由路径时定义好的
 
{path: '/a/:num', name: A, component: A}

2.$router.push

 push跳转时在函数内定义好携带过去的参数,在下个页面通过$route.params拿到

<button @click="deliverParams(123)">push传参</button>
  methods: {
    deliverParams (id) {
      this.$router.push({
        path: `/d/${id}`
      })
    }
  }
 
//拿到参数
mounted () {
  this.id = this.$route.params.id
}
 
//路由配置
{path: '/d/:id', name: D, component: D}

3.通过路由属性中的name匹配路由,再根据params传递参数

//写好要push去到的组件名
 
<button @click="deliverByName()">params传参</button>
    deliverByName () {
      this.$router.push({
        name: 'B',
        params: {
          sometext: '一只羊出没'
        }
      })
    }
 
//跳转后params拿到数据
<template>
  <div id="b">
    This is page B!
    <p>传入参数:{{this.$route.params.sometext}}</p>
  </div>
</template>
 
//路由规则定义
{path: '/b', name: 'B', component: B}

4.通过query来传递参数

//定义路由事件
<button @click="deliverQuery()">query传参</button>
    deliverQuery () {
      this.$router.push({
        path: '/c',
        query: {
          sometext: '这是小羊同学'
        }
      })
    }
 
//跳转后拿到数据
<template>
  <div id="C">
    This is page C!
    <p>这是父组件传入的数据: {{this.$route.query.sometext}}</p>
  </div>
</template>
 
//路由配置 无需做任何额外配置
{path: '/c', name: 'C', component: C}

注:通过这种方式拿到的数据会显示在url中

http://localhost:8080/#/c?sometext=%E8%BF%99%E6%98%AF%E5%B0%8F%E7%BE%8A%E5%90%8C%E5%AD%A6

总结:

1.传参的是this.$router,接收参数是this.$route,易混淆。前者是VueRouter的实例对象,而后者则是一个跳转的路由对象,每一个路由都会有一个route对象,是一个局部的对象。

2.params是通过name属性传递数据给指定的组件,query是通过path的配置将数据传递到指定path的地址。

3.通过query传递的数据在刷新页面的时候不会消失,而params传递的数据刷新页面得时候会消失,可以通过本地存储解决。 

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue3插槽(slot)使用方法详解

    Vue3插槽(slot)使用方法详解

    在VUE开发项目的过程中,插槽<slot>是重要的承载分发内容的出口,下面这篇文章主要给大家介绍了关于Vue3插槽(slot)使用的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • vue 巧用过渡效果(小结)

    vue 巧用过渡效果(小结)

    这篇文章主要介绍了vue 巧用过渡效果(小结),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • 详解vue-router的导航钩子(导航守卫)

    详解vue-router的导航钩子(导航守卫)

    这篇文章主要介绍了详解vue-router的导航钩子(导航守卫),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Vue开发实践指南之应用入口

    Vue开发实践指南之应用入口

    这篇文章主要给大家介绍了关于Vue开发实践指南之应用入口的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-01-01
  • vue在index.html中引入静态文件不生效问题及解决方法

    vue在index.html中引入静态文件不生效问题及解决方法

    这篇文章主要介绍了vue在index.html中引入静态文件不生效问题及解决方法,本文给大家分享两种原因分析,通过实例代码讲解的非常详细 ,需要的朋友可以参考下
    2019-04-04
  • Vue核心概念Getter的使用方法

    Vue核心概念Getter的使用方法

    今天小编就为大家分享一篇关于Vue核心概念Getter的使用方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • vue实现数据控制视图的原理解析

    vue实现数据控制视图的原理解析

    这篇文章主要介绍了vue如何实现的数据控制视图的相关知识,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • 安装nvm node版本管理器的操作方法(vue2.x迁移vue3.x)

    安装nvm node版本管理器的操作方法(vue2.x迁移vue3.x)

    这篇文章主要介绍了安装nvm node版本管理器(vue2.x迁移vue3.x)的操作方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-01-01
  • vue+openlayers绘制省市边界线

    vue+openlayers绘制省市边界线

    这篇文章主要为大家详细介绍了vue+openlayers绘制省市边界线,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • Vue3 reactive响应式赋值页面不渲染的解决

    Vue3 reactive响应式赋值页面不渲染的解决

    这篇文章主要介绍了Vue3 reactive响应式赋值页面不渲染的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08

最新评论