vue中路由传参和接参

方法一:params 传参

javascript 复制代码
this.$router.push({
    name:"admin",
    //这里的params是一个对象,id是属性名,item.id是值(可以从当前组件或者Vue实例上直接取)
    params:{id:item.id}
})    
 
//这个组件对应的路由配置
{
  //组件路径
  path: '/admin',
  //组件别名
  name: 'admin',
  //组件名
  component: Admin,
}

通过 params 传递参数,如果我们想获取 id 的参数值,可以通过 this.$route.params.id

javascript 复制代码
//vue接收页面
let id= this.$route.params.id;
let name= this.$route.params.name;

⚠️特别注意:获取参数的时候是 route,跳转和传参的时候是 r o u t e r 。(注意route与router的区别)

demo
javascript 复制代码
// 传递
<div
    class="box df-column"
    v-for="(item, index) in descList"
    :key="index"
    @click="goToDetail(item, 'policyInterpretation')"
  ></div>

goToDetail(data, name) {
      this.$router.push({
       name,
        params: {
          data,
        }
      })
      console.log(data, "政策中心");
    },

// 接收
    console.log(this.$route.params) // 必须配合name使用

方法二:路由属性配置传参

javascript 复制代码
this.$router.push({
    path:"/admin/${item.id}",
})    
 
//这个组件对应的路由配置
{
  //组件路径
  path: '/admin:id',
  //组件别名
  name: 'admin',
  //组件名
  component: Admin,
}

通过路由属性配置传参我们可以用 this.$route.params.id 来获取到 id 的值。

javascript 复制代码
//vue接收页面
let id= this.$route.params.id;
let name= this.$route.params.name;

⚠️注意:this.$router.push 方法里面路径带的是值, 路由配置项那里带的是变量名(属性名)来实现的对应。

以上两种传参方式基本上可以理解为 ajax 中的 post 请求方式,参数都是不可见的,但是上面两种方法都有一个弊端,就是当页面刷新了是获取不到参数值的,那么有没有一种方法是页面刷新之后参数依然存在呢? 👇

方法三:query 传参

javascript 复制代码
this.$router.push({
	name:"/admin",
	query:{
	    id:item.id,
	    name:item.name,
	}
})

//这个组件对应的路由配置
{
  //组件路径
  path: '/admin',
  //组件别名
  name: 'admin',
  //组件名
  component: Admin,
}

通过 query 传参,如果我们想获取 id 的参数值,可以通过 this.$route.query.id

javascript 复制代码
//vue接收页面
let id= this.$route.query.id;
let name= this.$route.query.name;

用 query 传参可以解决页面刷新参数消失问题,这种方式可以理解为是 ajax中的 get 方法,参数是直接在 url 后面添加的,参数是可见的。

方法四:localStorage

javascript 复制代码
// 存数据
localStorage.setItem("numbers", JSON.stringify(this.numbers));

// 取数据
this.numbers = JSON.parse(localStorage.getItem("numbers"));

但是注意使用 localStorage 时,如果变量名起的过于普通可能容易被其它页面存的数据覆盖。

相关推荐
love530love4 小时前
Scoop 完整迁移指南:从 C 盘到 D 盘的无缝切换
java·服务器·前端·人工智能·windows·scoop
i220818 Faiz Ul5 小时前
计算机毕业设计|基于springboot + vue鲜花商城系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
王码码20356 小时前
Flutter for OpenHarmony:Flutter 三方库 bluez 玩转 Linux 风格的蓝牙操作(蓝牙底层互操作)
linux·运维·服务器·前端·flutter·云原生·harmonyos
暴力袋鼠哥7 小时前
基于 Spring Boot 3 + Vue 3 的农产品在线销售平台设计与实现
vue.js·spring boot·后端
chilavert3188 小时前
技术演进中的开发沉思-371:final 关键字(中)
java·前端·数据库
2301_816997888 小时前
Vite构建工具
前端
yuki_uix9 小时前
深入理解 reduce:从面试题到设计思维
前端
凌云拓界9 小时前
TypeWell全攻略(二):热力图渲染引擎,让键盘发光
前端·后端·python·计算机外设·交互·pyqt·数据可视化