【Vue】在 Vue Router 中传递和解析对象数据

当我们需要在不同页面之间传递对象数据时,通常会使用 Vue Router 的 this.$router.push 方法进行导航,并通过 query 参数传递数据。然而,直接传递对象会导致数据丢失或不正确解析的问题,因为对象不能直接被编码成 URL 查询参数形式。

为了解决对象数据传递和解析的问题,我们可以将对象先转换为字符串,并对字符串进行 URL 编码。在发送端,可以使用 JSON.stringify 方法将对象转换为字符串,然后使用 encodeURIComponent 函数对字符串进行编码。在接收端,使用 decodeURIComponent 函数对 URL 查询参数进行解码,并使用 JSON.parse 方法将字符串解析为对象。

// 发送端页面
this.$router.push({
  name: "Index",
  query: { data: encodeURIComponent(JSON.stringify(data)) }
});

// 接收端页面
const decodedData = JSON.parse(decodeURIComponent(this.$route.query.data));

Vue RouterVue.js 官方的路由管理器。它和 Vue.js 的核心深度集成,让构建单页应用变得易如反掌。在 Vue Router 传递对象,通常是通过路由的 `params` 或者 `query` 来实现的。 1. 使用 `params` 传递对象: 如果你想通过动态路由传递对象,可以在路由路径使用参数,并在 `params` 传递对象。首先,需要在路由配置定义一个接收参数的路由: ```javascript { path: '/user/:id', component: User, } ``` 然后,在跳转到该路由的时候,将对象序列化后作为 `params` 传递: ```javascript this.$router.push({ name: 'User', params: { id: JSON.stringify(userObject) } }); ``` 在目标组件,可以通过 `this.$route.params` 获取到序列化后的对象字符串,然后进行反序列化: ```javascript const userObject = JSON.parse(this.$route.params.id); ``` 2. 使用 `query` 传递对象: 另一种方法是通过查询字符串(query)传递对象。这种方式不需要在路由配置做任何改变,只需要在跳转时将对象转换为查询参数: ```javascript this.$router.push({ name: 'User', query: { user: JSON.stringify(userObject) } }); ``` 在目标组件,同样使用 `this.$route.query` 获取到序列化后的对象字符串,并反序列化: ```javascript const userObject = JSON.parse(this.$route.query.user); ``` 需要注意的是,在这两种方式传递对象时,由于 URL 只能包含字符串,因此对象必须先转换成字符串形式。而在目标组件,需要将这个字符串再转换回对象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值