JSON.parse(JSON.stringify(undefined))报错

一、现象

使用数据时涉及到了简单的深拷贝数据,我使用了简单粗暴的JSON.parse(JSON.stringify(***))来做,但这引发了一个未知错误(其实是自己无知了),即我深拷贝的这个对象的值会有undefined的时候,此时就会报错

JSON.parse(JSON.stringify(undefined))

// 报错
Uncaught SyntaxError: Unexpected token u in JSON at position 0
    at JSON.parse (<anonymous>)
    at <anonymous>:1:6

在这里插入图片描述

二、反思

这个问题给我带来了非常大的困扰,因为我是在表单的自定义校验中使用的,表单的自定义校验代码出错时控制台是无法打出log的,这是我通过排除法定位到的问题,我又做了更多的实验

在这里插入图片描述

最终发现是问题是JSON.parse(),它是无法对undefinedor ''进行解析的
JSON.parse()内容必须符合JSON格式规范,具体可以查看菜鸟和w3c等

三、解决方案

let obj = JSON.stringify(undefined)
let obj2 = obj && JSON.parse(obj) || {};

在这里插入图片描述

即操作前先判断数值是否存在
以后看文档的时候要 多注意接参的要求和返回值的类型!!!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值