每日一题:请实现一个 JSON.stringify

该博客详细介绍了JavaScript的JSON.stringify()方法的模拟实现,包括转换规则和各种数据类型的处理方式。对于对象和数组,特别是对于特殊类型如undefined、函数、symbol以及循环引用的情况进行了深入探讨。同时,博客还提供了处理JSON的parse和stringify函数的示例代码。
摘要由CSDN通过智能技术生成

概念解释
JSON.stringify([,replacer,[,space]])方法是将一个 JavaScript 值(对象或者数组)转换为一个 JSON 字符串。此处模拟实现,不考虑可选的第二个参数 replacer 和第三个参数 space

转换规则如下:

基本数据类型

undefined 转换之后仍是 undefined(类型也是 undefined)

boolean 值转换之后是字符串 “false”/“true”

number 类型(除了 NaN 和 Infinity)转换之后是字符串类型的数值

symbol 转换之后是 undefined

null 转换之后是字符串 “null”

string 转换之后是字符串 string

NaN 和 Infinity 转换之后是字符串 “null”

如果是函数类型

转换之后是 undefined

如果是对象类型(非函数)

如果有 toJSON()方法,那么序列化 toJSON()的返回值

如果是一个数组,如果属性值中出现了 undefined、任意的函数以及 symbol,转换成字符串"null"

如果是 RegExp 对象,返回{}(类型是 string)

如果是 Date 对象,返回 Date 的 toJSON 字符串值

如果是普通对象

如果属性值中出现了 undefined、任意的函数以及 symbol 值,忽略
所有以 symbol 为属性键的属性都会被完全会忽略掉
对包含循环引用的对象(对象之间相互引用,形成无限循环)执行此方法,会抛出错误

if (!window.JSON) {
  window.JSON = {
    parse: function (sJSON) {
      return eval("(" + sJSON + ")");
    },
    stringify: (function () {
      var toString = Object.prototype.toString;
      var isArray =
        Array.isArray ||
        function (a) {
          return toString.call(a) === "[object Array]";
        };
      var escMap = {
        '"': '\\"',
        "\\": "\\\\",
        "\b": "\\b",
        "\f": "\\f",
        "\n": "\\n",
        "\r": "\\r",
        "\t": "\\t",
      };
      var escFunc = function (m) {
        return (
          escMap[m] ||
          "\\u" + (m.charCodeAt(0) + 0x10000).toString(16).substr(1)
        );
      };
      var escRE = /[\\"\u0000-\u001F\u2028\u2029]/g;
      return function stringify(value) {
        if (value == null) {
          return "null";
        } else if (typeof value === "number") {
          return isFinite(value) ? value.toString() : "null";
        } else if (typeof value === "boolean") {
          return value.toString();
        } else if (typeof value === "object") {
          if (typeof value.toJSON === "function") {
            return stringify(value.toJSON());
          } else if (isArray(value)) {
            var res = "[";
            for (var i = 0; i < value.length; i++)
              res += (i ? ", " : "") + stringify(value[i]);
            return res + "]";
          } else if (toString.call(value) === "[object Object]") {
            var tmp = [];
            for (var k in value) {
              if (value.hasOwnProperty(k))
                tmp.push(stringify(k) + ": " + stringify(value[k]));
            }
            return "{" + tmp.join(", ") + "}";
          }
        }
        return '"' + value.toString().replace(escRE, escFunc) + '"';
      };
    })(),
  };
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值