JSON.parse 和 JSON.stringify 的兼容实现

别人的实现

这里说的别人的实现就是:

https://github.com/douglascrockford/JSON-js/blob/master/json2.js

将上述的 js 下载下来在项目中引入就可以了,使用时还是调用 JSON.parseJSON.stringify

其实人家实现的就挺好,各种情况都想到和处理了,代码自然也很规范。但是我当时不知为什么就是不想引入#傲娇脸#,想想自己写一个还能咋的,于是就写了下面不规范的简单实现。

我的实现

先说 JSON.parse 的简单实现吧。这个真的是非常简单:$.parseJSON。你没有看错,这个 $ 就是 jQuery

当然,这必须得项目中引用了 jQuery。但是 jQuery 并没有提供一个类似 $.stringify 的实现,差评。

所以,如果项目中引入了 jQuery 但是还是要用到 JSON.stringify 函数,同时又像我一样莫名其妙地不想引入其他别人的实现时,那么就自己实现吧。

(function () {
    if (typeof window.JSON !== 'object') {
        window.JSON = {
            parse: function (jsonStr) {
                return eval('(' + jsonStr + ')'); 
            },
            stringify: function (jsonObj) {
                let items = [],
                    result = '',
                    type = Object.prototype.toString.call(jsonObj); // 数据类型

                if (type === '[object Array]') {
                    // 数组
                    jsonObj.forEach(function (item) {
                        items.push(window.JSON.stringify(item));
                    });
                    result = '[' + items.join(',') + ']';
                } else if (type === '[object Object]') {
                    // 对象
                    for (let item in jsonObj) {
                        items.push('"' + item + '":' + window.JSON.stringify(jsonObj[item]));
                    }
                    result = '{' + items.join(',') + '}';
                } else if (type === '[object String]') {
                    // 字符串
                    result = '"' + jsonObj.replace(/\\/g, '\\\\').replace(/"/g, '\\"').replace(/[\n\r]/g, '\\n') + '"';
                } else {
                    // 其他数据类型
                    result = jsonObj;
                }
                return result;
            }
        };
    }
})();