大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE稳定放心使用
讲这个问题之前先普及一下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博客
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/180810.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...