本文主要是介绍vue中路由传参和接参,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
方法一:params 传参
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。
//vue接收页面
let id= this.$route.params.id;
let name= this.$route.params.name;
⚠️特别注意:获取参数的时候是 route,跳转和传参的时候是 r o u t e r 。(注意route与router的区别)
demo
// 传递
<divclass="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使用
方法二:路由属性配置传参
this.$router.push({path:"/admin/${item.id}",
}) //这个组件对应的路由配置
{//组件路径path: '/admin:id',//组件别名name: 'admin',//组件名component: Admin,
}
通过路由属性配置传参我们可以用 this.$route.params.id 来获取到 id 的值。
//vue接收页面
let id= this.$route.params.id;
let name= this.$route.params.name;
⚠️注意:this.$router.push 方法里面路径带的是值,路由配置项那里带的是变量名(属性名)来实现的对应。
以上两种传参方式基本上可以理解为 ajax 中的 post 请求方式,参数都是不可见的,但是上面两种方法都有一个弊端,就是当页面刷新了是获取不到参数值的,那么有没有一种方法是页面刷新之后参数依然存在呢? 👇
方法三:query 传参
this.$router.push({name:"/admin",query:{id:item.id,name:item.name,}
})//这个组件对应的路由配置
{//组件路径path: '/admin',//组件别名name: 'admin',//组件名component: Admin,
}
通过 query 传参,如果我们想获取 id 的参数值,可以通过 this.$route.query.id。
//vue接收页面
let id= this.$route.query.id;
let name= this.$route.query.name;
用 query 传参可以解决页面刷新参数消失问题,这种方式可以理解为是 ajax中的 get 方法,参数是直接在 url 后面添加的,参数是可见的。
方法四:localStorage
// 存数据
localStorage.setItem("numbers", JSON.stringify(this.numbers));// 取数据
this.numbers = JSON.parse(localStorage.getItem("numbers"));
但是注意使用 localStorage 时,如果变量名起的过于普通可能容易被其它页面存的数据覆盖。
这篇关于vue中路由传参和接参的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!