为了账号安全,请及时绑定邮箱和手机立即绑定

如何在 Vue.js 中传递 $router.push 中的数组?

如何在 Vue.js 中传递 $router.push 中的数组?

PHP
Qyouu 2022-07-16 16:18:12
我想通过 VUE 的功能将数据传递到单击按钮的新页面。我尝试使用路由器方法做这件事,但我无法发送数组,它只是允许我用它发送一个字符串。this.$router.push({    name: "SalesInvoice",    params: { SalesInvoice: this.stockmaster }  });这件事不起作用,因为 stockmaster 是一个数组。this.$router.push({    name: "SalesInvoice",    params: { SalesInvoice: "abc" }  });我对字符串做了同样的事情,它奏效了。那么有什么方法可以使用 vue 方法将数组发送到下一页。
查看完整描述

2 回答

?
凤凰求蛊

TA贡献1825条经验 获得超4个赞

只需添加我的评论作为答案,以便其他人将来可以轻松获得它。


当您尝试将数组、对象或对象数组传递给路由器时,您应该首先stringify使用您的数据JSON.stringify并将其传递给路由器。然后您可以访问它并将其解析回JSONwith JSON.parse。对于上述特殊情况,应执行以下操作


this.$router.push({

    name: "SalesInvoice",

    params: { SalesInvoice: JSON.stringify(this.stockmaster) }

  });


查看完整回答
反对 回复 2022-07-16
?
qq_花开花谢_0

TA贡献1835条经验 获得超7个赞

作为参考,我不建议使用JSONas URL 参数,而是使用query参数。如果要将数据从一个请求发送到下一个请求,通常使用查询参数而不是路由参数。


在您的情况下,将代码更改为


this.$router.push({

    name: "SalesInvoice",

    query: { SalesInvoice: "abc" }

  });

然后,您可以将您的路线定义更改为这样的


{

  path: 'sales-invoice', 

  name: 'SalesInvoice',

}

看,路径中没有更多:SalesInvoice内容了。不再需要路由参数,因为您现在通过查询参数将数据提供给新路由。您可以使用任意数量的查询参数(实际上是 URL 允许的最大长度),而无需在路由定义中定义它们。这为您提供了更大的灵活性。


您可以使用类似于访问路由参数的查询参数this.$route.query.SalesInvoice。


查看完整回答
反对 回复 2022-07-16
  • 2 回答
  • 0 关注
  • 526 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信