使用JSON.parse字符串转换json报错解决办法

解决办法

问题点

字符串格式不是很完美,导致JSON.parse转换失败。JSON.parse()方法对字符串的格式要求极其严格。一点格式错误都不能有,否则就报异常。

解决方案

要么改掉你的json字符串,要么使用$parseJSON或者eval的方式生成json对象。

问题产生的背景

获取post的值

在获取小程序的二维码返回参数的时候。

为了保证数据的安全性,走了POST的请求方式。

POST的数据提交返回后,经过了decodeURIComponent转换之后。变成了类似JSON串的方式呈现。

例如id:101,pid:102

这种格式一看到就想往json转。

毕竟json还是很方便的。

用json的话,很方便就考虑到嵌入的JSON。

JSON

JSON就两个常用方法

JSON.stringify()

JSON.parse()

一个是json对象转字符串,一个是字符串转json对象。

就是这两个简单的方法,中间用的时候出现了一些问题。

曾经的自以为是

无效的代码

先上下代码

let sence = 'id:1,name:张三'

let obj = JSON.parse("{"+sence +"}")

this.id = obj.id

结果很打脸

理想很丰满,现实很骨感。

直接报错了。

针对报错的最常规手法就是debugger、console.log()了。

发现使用JSON.stringify()输出数据很正常。

一转换json对象就可以报异常了。

人民的大救星

百度,百度,找到一条出路

这就很纠结了,百度吧,百度吧,百度吧

网上说是因为格式不严谨,所以就报异常了。

JOSN.parse对格式要求非常严格。

那怎么办呢?

对于这种后台传递过来的没有引号的

大部分都推荐使用eval()或者$.parseJSON方法转换为json对象。

let sence = 'id:1,name:张三'

let obj =  ( Function( "return " + sence ) )()

console.log(JSON.stringify(obj))

this.id = obj.id

结果完美转换。引号都给加上了。

孰是孰非

一家之言

$.parseJSONJSON.parse和eval还是有些区别的。

类型$parseJSONJSON.parseeval
方法说明jquery的方法。将符合标准格式的的JSON字符串转为与之对应的JavaScript对象只能解析属性名是双引号包裹的字符串对象可将一个JavaScript代码字符串求值成特定的对象
主要区别字符串必须用双引号括起来。必须严格遵守json字符串格式;属性名称必须用双引号包裹;
字符串必须用双引号括起来。
字符串必须用双引号括起来。
使用场景能用JSON.parse的都可以用这个json字符串必须严格符合json格式。可以用在后端传递给前端数据格式的使用使用。对数据的严谨性可以格式不规范的时候,当你不能确认对方的数据格式是不是很严谨的时候
推荐程度推荐一般不推荐
  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: JSON.parse(JSON.stringify(obj)) 是一种常用的深拷贝对象的方法。它的作用是先使用 JSON.stringify 将 JavaScript 对象序列化为 JSON 字符串,然后再使用 JSON.parseJSON 字符串反序列化为 JavaScript 对象。这样可以实现对象的深拷贝,即创建一个与原对象完全相同的新对象。然而,有一些情况下会出现报错,比如 Uncaught SyntaxError: Unexpected token u in JSON at position 0。这个错误通常是因为对象中包含了 undefined 或其他无法被序列化为 JSON 的值。\[1\] 另外,需要注意的是,如果对象中包含时间对象,经过 JSON.stringify 和 JSON.parse 后,时间对象会被转换字符串形式,而不是保持为时间对象。例如,如果对象中有一个属性是时间对象,如 { date: new Date() },经过 JSON.stringify 后,该属性的值将变为字符串形式,如 { "date": "2022-01-01T00:00:00.000Z" }。再经过 JSON.parse 后,该属性的值将变为字符串类型,而不是时间对象。\[2\] 总结来说,JSON.parse(JSON.stringify(obj)) 是一种常用的深拷贝对象的方法,但需要注意处理对象中包含 undefined 或其他无法被序列化为 JSON 的值的情况,以及时间对象被转换字符串的情况。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [研究一下 JSON.parse(JSON.stringify(obj))](https://blog.csdn.net/wswq2505655377/article/details/125879881)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [JSON.parse(JSON.stringify(obj))实现深拷贝](https://blog.csdn.net/china_coding/article/details/126635331)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [使用JSON.parse(JSON.stringify(obj))进行深拷贝时的注意事项](https://blog.csdn.net/qq_43807473/article/details/123825413)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值