首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

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

    比如说,它无法处理函数、undefined、Symbol 等特殊类型的数据,这些数据在转换成 JSON 字符串时会被忽略掉。此外,如果对象中存在循环引用,JSON.stringify 也会报错。...6、包装对象处理:自动转换为原始值 在使用 JSON.stringify 时,有一个很重要的特性是,布尔值、数字和字符串的包装对象在序列化时会自动转换为它们对应的原始值。...处理 Map、Set 等对象 类似地,对于 Map、Set 等对象,JSON.stringify 也只会序列化它们的可枚举属性,而这些对象的特殊数据结构本身不会被直接序列化。...循环引用的问题 当对象存在循环引用时,JSON.stringify() 会抛出错误,因为 JSON 不支持循环结构。...形成了一个循环引用,这导致 JSON.stringify() 在处理时抛出了 TypeError 错误。

    18510

    Javascript的JSON.stringify()知多少?

    写在前面 前几天看到前端胖头鱼的一篇文章《就因为JSON.stringify,我的年终奖差点打水漂了》,讲的就是JSON.stringify在工程开发中的应用,线上用户不能提交表单。...JSON.stringify() JSON.stringify是日常开发中经常用到的JSON对象中的一个方法,用于将一个 JavaScript 对象或值转换为 JSON 字符串,如果指定了一个 replacer...注意: 循环引用的对象(对象之间相互引用,形成无限循环)执行此方法,会抛出错误。 布尔值、数字、字符串的包装对象在序列化过程中会自动转换成对应的原始值。...undefined、任意的函数以及symbol值,在序列化过程中会被忽略(出现在非数组对象的属性值中时)或者被转换成 null(出现在数组中时)。...()》 《就因为JSON.stringify,我的年终奖差点打水漂了》 写在最后 我们平时开发中将JSON.stringify应用最多的可能就是浅层的对象进行深拷贝,也就是进行序列化处理。

    1.3K00

    慎用JSON.stringify

    简单来说,JSON.stringify() 就是将值转换为相应的 JSON 格式字符串。...值会被转换成 null JSON.stringify([undefined, Object, Symbol("")]); // '[null,null,null]' 一种是非数组对象,在序列化的过程中会被忽略...(anonymous>) at anonymous>:1:6 以 symbol 为属性键的属性,慎用 所有以 symbol 为属性键的属性都会被完全忽略掉,即便 replacer 参数中强制指定包含了它们...(person)) // {"age":"25"} 总结 JSON.stringify 在实际应用中确实很方便的解决了我们很多问题,比如简单的深拷贝等。...但是我们在使用时候,也需要知道它有哪些不足之处,在目标值如果是一些特殊值的情况下,可能序列化后的结果会不符合我们的预期,这个时候就需要慎用 参考 JSON.stringify converting Infinity

    1K30

    你不知道的 JSON.stringify

    JSON.stringify是我们经常用到的的一个方法,它主要作用是将 JavaScript 值和对象转换为字符串。...对包含循环引用的对象(对象之间相互引用,形成无限循环)执行此方法,会抛出错误 我认为 JSON.stringify 能够返回字符串以外的东西是挺惊讶的。...JSON.stringify 也可能遇到问题,导致它抛出一个错误。在正常情况下,有四种情况会发生: 循环引用会导致抛出一个类型错误。...const b = { a }; a.b = b; JSON.stringify(a); // => TypeError: cyclic object value 注意,这些错误消息在不同浏览器可能提示是不样的...处理循环引用 根据个人经验,JSON.stringify 在传递循环引用时最容易出错。如果这对你来说是一个常见的问题,我推荐 json-stringify-safe 包,它能很好地处理这种情况。

    3.3K20

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

    了解一下 JSON.stringify 其实,这个bug主要是因为胖头对JSON.stringify不熟悉造成的,所以,这里我们就一起来分析一下这个内置函数的一些特点。...基本上,JSON.stringify() 方法将 JavaScript 对象或值转换为 JSON 字符串: 同时,JSON.stringify 有以下规则。...2、 Boolean、Number、String 对象在字符串化过程中被转换为对应的原始值,符合传统的转换语义。...7、 所有其他 Object 实例(包括 Map、Set、WeakMap 和 WeakSet)将仅序列化其可枚举的属性。 8、找到循环引用时抛出TypeError(“循环对象值”)异常。...9、 尝试对 BigInt 值进行字符串化时抛出 TypeError(“BigInt 值无法在 JSON 中序列化”)。 自己实现 JSON.stringify 理解一个函数的最好方法是自己实现它。

    43620

    你不知道的JSON.stringify

    [bmuwt4me9c.gif] 点击上方蓝色字体,关注我们 最近使用 Vue 写后台管理系统,在做 Tab 组件的持久化时遇到一个问题: localStorage.setItem('tabs',JSON.stringify...(tabs)) 上面代码报错: [f0np2w3fta.png] 看意思应该是产生了循环引用的结构,下面是不同浏览器对于这个类型错误报出错的形式: TypeError: cyclic object value...(Firefox) TypeError: Converting circular structure to JSON (Chrome and Opera) TypeError: Circular reference...既然是由于循环引用导致的,那我们可以在发生循环引用的地方给切断。 那如何切断呢?...幸好 JSON.stringify 方法提供了便利,语法如下: JSON.stringify(value[, replacer[, space]]) replacer 可以作为一个函数传入,且接受 key

    93620

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

    ❞ 看完本文您可以收获: 了解一个差点让我年终奖打水漂的悲伤的故事o(╥﹏╥)o 学习JSON.stringify的9大特性和转换规则 「(重点)」 了解如何判断一个对象是否存在循环引用 「(重点)」...学透JSON.stringify ❝JSON.stringify() 方法将一个 JavaScript 对象或值转换为 JSON 字符串,如果指定了一个 replacer 函数,则可以选择性地替换值,或者指定的...异常[2] 当在循环引用时会抛出异常TypeError ("cyclic object value")(循环对象值) 当尝试去转换 BigInt 类型的值会抛出TypeError ("BigInt value...)) // undefined console.log(JSON.stringify(Symbol('前端胖头鱼'))) // undefined 特性二 ❝布尔值、数字、字符串的包装对象在序列化过程中会自动转换成对应的原始值...) console.log(JSON.stringify(alsoHuge)) // TypeError: Do not know how to serialize a BigInt 手写一个JSON.stringify

    1.1K20

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

    了解一下 JSON.stringify 其实,这个bug主要是因为胖头对JSON.stringify不熟悉造成的,所以,这里我们就一起来分析一下这个内置函数的一些特点。...基本上,JSON.stringify() 方法将 JavaScript 对象或值转换为 JSON 字符串: 同时,JSON.stringify 有以下规则。...2、 Boolean、Number、String 对象在字符串化过程中被转换为对应的原始值,符合传统的转换语义。...7、 所有其他 Object 实例(包括 Map、Set、WeakMap 和 WeakSet)将仅序列化其可枚举的属性。 8、找到循环引用时抛出TypeError(“循环对象值”)异常。...9、 尝试对 BigInt 值进行字符串化时抛出 TypeError(“BigInt 值无法在 JSON 中序列化”)。 自己实现 JSON.stringify 理解一个函数的最好方法是自己实现它。

    45710

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

    本文将详细介绍 JSON.stringify() 的属性、应用场景,并提供一个完整而优雅的实现,处理循环引用、特殊类型(如日期和正则表达式)以及性能相关的问题。...应用场景 JSON.stringify() 在以下场景中非常有用: a....数据存储 如果需要将 JavaScript 对象保存到本地存储(如浏览器的 LocalStorage 或数据库),可以使用 JSON.stringify() 将对象转换为 JSON 字符串后进行存储。...建议在实际使用中参考第三方库或更全面的文档和资源。 4. 注意事项 在使用 JSON.stringify() 时,需要注意以下事项: a....记住,JSON.stringify() 是处理 JSON 数据的强大工具,但在特殊情况下需要特别小心,确保正确处理特殊类型和避免循环引用的问题。

    22420

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

    这是JS 原生方法原理探究系列的第八篇文章。本文会介绍如何实现 JSON.stringify() 方法。 JSON.stringify() 可以将对象或值转化为 JSON 字符串。...检测循环引用 循环引用指的是对象的结构是回环状的,不是树状的: // 下面的对象/数组存在循环引用 let obj = {}; obj.a = obj; let obj1 = { a: { b: {}...') } } }) console.log('不存在循环引用') } 在 JSON.stringify 的实现中,遍历 key 的过程已经在主代码完成了...在整个过程中不需要去处理 JSON 字符串中的逗号分隔符。...最后,我并没有实现 JSON.stringify() 中的 replacer 参数和 space 参数,感兴趣的读者可以在上面代码的基础上进一步拓展。 本文到此结束,感谢你的阅读。

    2K50
    领券