JSON.parse 解析json字符串时,遇换行符报错

5 篇文章 0 订阅
1 篇文章 0 订阅

Json字符串转换成Json对象时候,有两种方式:假设d是json字符串:
1,eval(’(’ + d + ‘)’);
2,JSON.parse(d);
但是以上方式有隐患,如果Json字符串有换行的话,这样转换就会报错。所以json字符串转对象时,是需要做一些过滤的。
假如有这样一个字符串:

var json='{"CityName":"西安","CityOrder":"物料::WAA010001\n物料名称::轴承\n规格型号::HRB1209\n供应商::东莞市耀光化工贸易有限公司\n采购员::\n请购部门:: \n批号::JH201803250001"}';

输出的结果报错
####错误原因:
JSON.parse转json字符串时遇到一些特殊字符需要先转义。
用str.replace(/\n/g,"\n")转义,’\‘转成单个’’,’\n’转成’\n’,最后转成’\n’这样就可以用parse转成对象时变为’\n’,取出的字符串设置到html文本中\n被解析为换行。
可以这样转义:.replace(/\n/g,"\n").replace(/\r/g,"\r")。
如下:

var jsonObj=JSON.parse(json.replace(/\n/g,"\\n").replace(/\r/g,"\\r"));

输出结果正确

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 当使用JSON.parse解析特殊字符,可能会。为了解决这个问题,可以使用引用\[2\]中提供的handleSpecialCharacters函数来处理特殊字符。该函数会将特殊字符进行转义,然后再进行JSON.parse解析。这样可以避免。另外,还可以使用引用\[1\]中提供的方法,将含有特殊字符的字符串进行替换,然后再进行JSON.parse解析。这样也可以解决的问题。 #### 引用[.reference_title] - *1* [JSON.parse解析json字符串换行符 原因以及如何解决](https://blog.csdn.net/m0_66288747/article/details/129931685)[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^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [【前端关于JSON.parse解析处理方案】](https://blog.csdn.net/beiluoL/article/details/125085711)[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^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [小程序选取上传图片以及视频,JSON.parse解析返回值](https://blog.csdn.net/m0_46978096/article/details/125327558)[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^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值