首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

差点因为 JSON.stringify 丢了奖金...

由于JSON.stringify的错误使用,他负责的其中一个业务模块上线后出现了bug,导致某个页面无法使用,进而影响用户体验,差点让他失去年终奖。 在这篇文章中,我将分享这个悲伤的故事。...产品经理先是抱怨:项目中有一个bug,用户无法提交表单,客户抱怨这个。请开发组尽快修复。 然后测试工程师说:我之前测试过这个页面,为什么上线后就不行了?...因此,此类数据上传到服务器后,服务器无法解析 value 字段,进而导致错误。...7、 所有其他 Object 实例(包括 Map、Set、WeakMap 和 WeakSet)将仅序列化其可枚举的属性。 8、找到循环引用时抛出TypeError(“循环对象值”)异常。...9、 尝试对 BigInt 值进行字符串化时抛出 TypeError(“BigInt 值无法在 JSON 中序列化”)。 自己实现 JSON.stringify 理解一个函数的最好方法是自己实现它。

45910

深浅拷贝

//注意目标对象不能为null或undefined Object.assign(null); // TypeError: Cannot convert undefined or null to...JSON.stringify()方法将对象转化为字符串,但只会处理简单属性和简单属性数组,constructor属性丢失了 如果obj里面有时间对象,则JSON.stringify后再JSON.parse...如果obj里有RegExp(正则表达式的缩写)、Error对象,则序列化的结果将只得到空对象; 如果obj里有函数,undefined,则序列化的结果会把函数或 undefined丢失; 如果obj里有...NaN、Infinity和-Infinity(正无穷和负无穷),则序列化的结果会变成null。...如果对象中存在循环引用的情况也无法正确实现深拷贝; 4.自定义对象数组深拷贝 function deepClone(obj) { if (typeof obj !

43941
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    js对象拷贝方法

    、各种数据类型都可以拷贝,引用类型不是深拷贝 它不会拷贝对象的继承属性; 它不会拷贝对象的不可枚举的属性; 不可以拷贝对象中的对象; 可以拷贝 Symbol 类型的属性; 无法正确拷贝属性和属性 可以拷贝...、各种数据类型都可以拷贝,引用类型不是深拷贝 JSON.parse(JSON.stringfiy()),不完全深拷贝 拷贝的对象的值中如果有函数、undefined、symbol 这几种类型,经过 JSON.stringify...序列化之后的字符串中这个键值对会消失; 拷贝 Date 引用类型会变成字符串; 无法拷贝不可枚举的属性; 无法拷贝对象的原型链; 拷贝 RegExp 引用类型会变成空对象; 对象中含有 NaN、Infinity...以及 -Infinity,JSON 序列化的结果会变成 null; 无法拷贝对象的循环引用,如果对象中有循环引用,会报错: Uncaught TypeError: Converting circular...,如果有循环引用会报错栈溢出 function cloneDeep(obj) { let objClone = obj.constructor === Array ?

    2.4K20

    面试官:请实现一个JavaScript深拷贝

    但是效果跟上面没有差别,所以我们不再细说了.前端进阶面试题详细解答2.深克隆2.1 JSON.parse方法前几年微博上流传着一个传说中最便捷实现深克隆的方法,JSON对象parse方法可以将JSON字符串反序列化成...JS对象,stringify方法可以将JS对象序列化成JSON字符串,这两个方法结合起来就能产生一个便捷的深克隆.const newObj = JSON.parse(JSON.stringify(oldObj..., oldObj.a); // TypeError: Converting circular structure to JSON对象的循环引用会抛出错误.2.2 构造一个深克隆函数我们知道要想实现一个靠谱的深克隆方法...JS对象,stringify方法可以将JS对象序列化成JSON字符串,这两个方法结合起来就能产生一个便捷的深克隆.const newObj = JSON.parse(JSON.stringify(oldObj..., oldObj.a); // TypeError: Converting circular structure to JSON对象的循环引用会抛出错误.2.2 构造一个深克隆函数我们知道要想实现一个靠谱的深克隆方法

    36230

    就因为JSON.stringify,我的年终奖差点打水漂了

    ❞ image.png 「直接错误原因」 ❝非必填情况下,signInfo字段中经过JSON.stringify后的字符串对象缺少value key,导致后端parse之后无法正确读取value值,进而报接口系统异常...,用户无法进行下一步动作。...之后的数据,少了value key,导致后端无法读取value值进行报错 // 具体原因是`undefined`、`任意的函数`以及`symbol值`,出现在`非数组对象`的属性值中时在序列化过程中会被忽略...异常[2] 当在循环引用时会抛出异常TypeError ("cyclic object value")(循环对象值) 当尝试去转换 BigInt 类型的值会抛出TypeError ("BigInt value...(alsoHuge)) // TypeError: Do not know how to serialize a BigInt 手写一个JSON.stringify ❝终于重新学完JSON.stringify

    1.1K20

    有个朋友因为 JSON.stringify 差点丢了奖金

    由于 JSON.stringify 的错误使用,他负责的其中一个业务模块上线后出现了 bug,导致某个页面无法使用,进而影响用户体验,差点让他失去年终奖。 在这篇文章中,我将分享这个悲伤的故事。...产品经理先是抱怨:项目中有一个bug,用户无法提交表单,客户抱怨这个。请开发组尽快修复。 然后测试工程师说:我之前测试过这个页面,为什么上线后就不行了?...因此,此类数据上传到服务器后,服务器无法解析 value 字段,进而导致错误。...7、 所有其他 Object 实例(包括 Map、Set、WeakMap 和 WeakSet)将仅序列化其可枚举的属性。 8、找到循环引用时抛出TypeError(“循环对象值”)异常。...9、 尝试对 BigInt 值进行字符串化时抛出 TypeError(“BigInt 值无法在 JSON 中序列化”)。 自己实现 JSON.stringify 理解一个函数的最好方法是自己实现它。

    44220

    掌握JavaScript的JSON.stringify鲜为人知的技巧,让前端开发更加高效和灵活

    比如说,它无法处理函数、undefined、Symbol 等特殊类型的数据,这些数据在转换成 JSON 字符串时会被忽略掉。此外,如果对象中存在循环引用,JSON.stringify 也会报错。...并不会返回 JSON 字符串,而是直接返回 undefined,表示这些值无法被序列化。...处理 Map、Set 等对象 类似地,对于 Map、Set 等对象,JSON.stringify 也只会序列化它们的可枚举属性,而这些对象的特殊数据结构本身不会被直接序列化。...循环引用的问题 当对象存在循环引用时,JSON.stringify() 会抛出错误,因为 JSON 不支持循环结构。...,这导致 JSON.stringify() 在处理时抛出了 TypeError 错误。

    20110

    你不知道的 JSON.stringify

    对包含循环引用的对象(对象之间相互引用,形成无限循环)执行此方法,会抛出错误 我认为 JSON.stringify 能够返回字符串以外的东西是挺惊讶的。...带有 toJSON 函数的对象将被运行,而不是试图正常地序列化它们。但是如果 toJSON 返回上面的一个值,试图在顶层序列化它将导致 JSON.stringify 返回undefined。...JSON.stringify 也可能遇到问题,导致它抛出一个错误。在正常情况下,有四种情况会发生: 循环引用会导致抛出一个类型错误。...BigInts不能用 JSON.stringify 进行序列化,这些也会导致一个TypeError。...处理循环引用 根据个人经验,JSON.stringify 在传递循环引用时最容易出错。如果这对你来说是一个常见的问题,我推荐 json-stringify-safe 包,它能很好地处理这种情况。

    3.3K20

    Javascript的JSON.stringify()知多少?

    因为字段中经过JSON.stringify后的字符串对象缺少value key,导致后端parse之后无法正确读取value值,进而报接口系统异常,用户无法进行下一步动作。...JSON.stringify(value[, replacer [, space]]) 复制代码 value:必填参数,需要序列化的JSON对象。 replacer:可选参数。...注意: 循环引用的对象(对象之间相互引用,形成无限循环)执行此方法,会抛出错误。 布尔值、数字、字符串的包装对象在序列化过程中会自动转换成对应的原始值。...('Do not know how to serialize a BigInt') } if (isCyclic(data)) { throw new TypeError('...()》 《就因为JSON.stringify,我的年终奖差点打水漂了》 写在最后 我们平时开发中将JSON.stringify应用最多的可能就是浅层的对象进行深拷贝,也就是进行序列化处理。

    1.3K00

    JS 原生方法原理探究(八):如何实现 JSON.stringify()?

    本文会介绍如何实现 JSON.stringify() 方法。 JSON.stringify() 可以将对象或值转化为 JSON 字符串。...检测循环引用 循环引用指的是对象的结构是回环状的,不是树状的: // 下面的对象/数组存在循环引用 let obj = {}; obj.a = obj; let obj1 = { a: { b: {}...') } } }) console.log('不存在循环引用') } 在 JSON.stringify 的实现中,遍历 key 的过程已经在主代码完成了...方法,产生一个标准的序列化结果; 如果处理的 target 是对象字面量,则可以将它的每个 key-value 的序列化结果 push 到 res 中,最终再和 {、} 字符拼接,也同样会产生一个标准的序列化结果...if (type == "Object" || type == "Array") { if (currentParent.includes(obj)) { throw new TypeError

    2K50

    《现代Javascript高级教程》深入理解JSON.stringify

    本文将详细介绍 JSON.stringify() 的属性、应用场景,并提供一个完整而优雅的实现,处理循环引用、特殊类型(如日期和正则表达式)以及性能相关的问题。...数据传输 当需要将 JavaScript 对象转换为字符串,以便在网络中传输给后端或其他系统时,可以使用 JSON.stringify() 进行序列化。...return value; } function replacer(key, value) { if (seen.has(value)) { throw new TypeError...注意事项 在使用 JSON.stringify() 时,需要注意以下事项: a. 循环引用 如果要序列化的对象存在循环引用,即对象之间相互引用,会导致无限递归的情况。...特殊类型 特殊类型(如日期和正则表达式)需要进行适当的处理,以确保正确的序列化和反序列化。 c. 性能优化 JSON.stringify() 可能会在处理大型对象或嵌套层次较深的对象时产生性能问题。

    23320
    领券