大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全家桶1年46,售后保障稳定
项目场景:
例如:点击table表格第一列进入详情页,这时候我们进行路由跳转就需要携带一些参数以便我们在详情页使用
跳转方式
一般我们有两种方式让路由携带参数
1.路由传参query(path是路由地址,query是需要传递的参数)
goDetail() {
this.$router.push({
path: "/publish",
query: {
roleName: "admin",
id: 1,
},
});
},
注意:如果传入的参数存在对象,则必须转成JSON字符串传入,接收的时候再转换
goDetail() {
let arr = [{
name:"admin",value:111},{
name:"admin2",value:222}]
this.$router.push({
path: "/publish",
query: {
roleName: JSON.stringify(arr),
id: 1,
},
});
},
2.路由传参params(name与路由的name对应,params是需要传递的参数)
goDetail() {
this.$router.push({
name: "publish",
params: {
roleName: "admin",
id: 1,
},
});
},
注意:params传参刷新页面的时候会丢失数据,解决方法是在路由的配置文件里给该路由后面拼接需要的参数
{
path: "/Publish/:roleName/:id",//:roleName与:id之间的/可以省略,看自己喜好
name: "publish",
component:import("../components/PublishApp"),
},
接收路由参数:
1.query的接收方式:
//参数不存在对象时
created() {
console.log(this.$route.query)
},
//参数存在对象时,只能单独取,直接打印query报错
created() {
console.log(JSON.parse(this.$route.query.roleName));
},
2.params的接收方式:
created() {
console.log(this.$route.params);
},
注意:
1.query相当于get请求,页面跳转的时候,可以在地址栏看到请求参数,而params相当于post请求,参数不会再地址栏中显示;
2.如果用params又不想刷新后丢失参数,只能拼在路由path后面;
3.个人觉得用params把参数拼在路由后面比query好看很多;
4.params想携带数组对象这些类型的数据,又不想刷新后丢失,我没找到解决办法,还是用query,有没有大神知道告诉我一下谢谢!!!
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/234925.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...