js解析json字符串报错解决方案(带有转义字符的json字符串)

场景:从后台请求回来的数据中带有json格式的字符串,需要处理成json对象才能进行操作。


json字符串

JSON.parse():

        使用JSON.parse方法来解析json字符串。

   

解析成功

报错:    Uncaught SyntaxError: Unexpected token } in JSON at position 30

               Uncaught SyntaxError: Unexpected token ' in JSON at position 1


报错信息

           这种报错是由于,json字符串的格式有问题,json字符串中对象的最后一个元素后面不可以再加','逗号了。比如'{ "name": "cxh", "sex": "man",}'使用JSON.parse()就会报错,而且在json字符串中键值对需要用双引号引起来。


js解析json字符串报错解决方案(带有转义字符的json字符串)_第1张图片
json多逗号


js解析json字符串报错解决方案(带有转义字符的json字符串)_第2张图片
json键值对是单引号

解决方案:使用eval()


js解析json字符串报错解决方案(带有转义字符的json字符串)_第3张图片
eval()解析json

报错:SyntaxError: Unexpected token e in JSON at position 1

        由于请求回来的json中带有转义字符,所以才会报这个错误。


js解析json字符串报错解决方案(带有转义字符的json字符串)_第4张图片
带有转义字符的json字符串

解决方案:带有转义字符的json字符串使用json

        json数据使用JSON.parse()有浏览器是不兼容JSON这个对象的,或者有的里面有JSON.parse解析不了的东西,所以暂时还是使用: eval("("+data+")");

        json源数据字符有转义符应该是必须的,你要看解析出来后是否有多余的转义符


eval方法解析成功

json转字符串JSON.stringify总体效果还可以:


JSON.stringify()

前导 0 和小数点报错:SyntaxError: JSON.parse: expected ',' or '}' after property value

                                     SyntaxError: JSON.parse: unterminated fractional number

                                     Uncaught SyntaxError: Unexpected number in JSON at position 25

                                     Uncaught SyntaxError: Unexpected token } in JSON at position 26

                                     

js解析json字符串报错解决方案(带有转义字符的json字符串)_第5张图片
数字前有0


        数字不能用 0 开头,比如01,并且你的小数点后面必须跟着至少一个数字。


js解析json字符串报错解决方案(带有转义字符的json字符串)_第6张图片
小数点后面无数字

你可能感兴趣的:(js解析json字符串报错解决方案(带有转义字符的json字符串))