JSON.parse()出错解决

在做微信小程序时遇到的问题,记录一下。

需求:

将购物车页面的商品信息通过url传到确认订单页
复制代码

购物车页面处理过程:

在购物车页面,处理商品信息组装成如下形式:
goodsInfoArr = [{"GoodsId":"12","GoodsImg":"http://a.example.com/xx/?sss/fgfg","GoodsTitle":"这里是title"}]
GoodsImg的url是后端传过来的商品图片的url形式
然后,将这个商品信息的数组通过JSON.stringify()转化成字符串,放在页面的url中传过去
goodsInfoStr = JSON.stringify(goodsInfoArr);
wx.navigateTo({
  url: 'test?goodsInfo=goodsInfoStr'
})
复制代码

确认订单页面处理过程:

在确认订单页面拿到url上的goosInfoStr之后,我们开始用JSON.parse(goosInfoStr)来解析这个数据
复制代码

此时,问题来了,页面报错了,原因是 img的地址里面 ?被截断了

解决方法
只要在购物车页面用encodeURIComponent()对goodsImg的url进行编码,然后在确认订单页利用decodeURIComponent()对url进行解码就可以了
goodsInfoArr = [{
    "GoodsId":"12",
    "GoodsImg":encodeURIComponent("http://a.example.com/xx/?sss/fgfg"),
    "GoodsTitle":"这里是title"
}]

JSON.parse(goodsInfoArr)
 然后用的时候就 decodeURIComponent(goodsInfoArr.GoodsImg)就可以了
复制代码
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值