(已解决)Unexpected token o in JSON at position 1

2022-11-02 15:22:44 浏览数 (1)

讲这个问题之前先普及一下JSON.parse()和JSON.stringify()方面的知识:

JSON.parse() 方法用于将一个 JSON 字符串转换为对象,如

var str = ‘{“name”:”LeonWu”,”age”:”18″}’ JSON.parse(str); //结果为一个Object // age: “18”; // name: “LeonWu”;

JSON.stringify() 方法是将一个JavaScript值(对象或者数组)转换为一个 JSON字符串,如

var a = {a:1,b:2,c:”LeonWu”}; JSON.stringify(a); //结果为 ‘{“a”:1,”b”:2,”c”:”LeonWu”}’

最近在做微信小程序项目,遇到了这个问题:

我是想把用户选择的东西传到另一个页面:

submit() { let cartlist = JSON.stringify(this.data.cart); //这里我又定义了一个变量接收转换后的对象,就是因为这里为后面埋下了伏笔 console.log(cartlist); wx.navigateTo({ url: ‘../order/order?cartlist=’ cartlist, }) }

另一个页面:

onLoad(options){ console.log(JSON.parse(options)); //哈哈没那么容易,报错了在这里 },

其实在这里我传过来的值是这样的:

{cartlist: ‘{“count”:1,”total”:2,”list”:{“1”:1}}’} //类型还是对象

这虽然是一个对象,但是不是json字符串,cartlist的值才是json字符串,所以这里我错了。JSON.parse(里面必须是一个json字符串)

修改后:

onLoad(options){ console.log(options.cartlist); //{“count”:1,”total”:3,”list”:{“2”:1}} let a = JSON.parse(options.cartlist); console.log(a.count); }, // 1

。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

如果你传参的时候没有指定一个值(上面那个cartlist)接收转换后的值(对象转为字符串),那你可以直接使用JSON.parse。

这里记录下我看过的类似问题的博客:

【已解决】Uncaught SyntaxError: Unexpected token o in JSON at position 1_硕士茂哥-CSDN博客

Unexpected token o in JSON at position 1 报错原因_积少成多-CSDN博客

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/180810.html原文链接:https://javaforall.cn

0 人点赞