1

我正在看MDN 的“使用原生 JSON”。我对这个JSON.stringify方法有 3 个问题。

问题一:

var foo = {
    "foundation": "Mozilla",
    "model": "box",
    "week": 45,
    "transport": "car",
    "month": 7
},
    censor = function (key, value) {
        if (typeof value === 'string') {
            return;
        }
        return value;
    };
console.log(JSON.stringify(foo, censor)); // String: {"week":45,"month":7}

上面的代码工作正常。但是为什么下面的代码不能正常工作?

var foo = {
    "foundation": "Mozilla",
    "model": "box",
    "week": 45,
    "transport": "car",
    "month": 7
},
    censor = function (key, value) {
        if (typeof value !== 'string') {
            return;
        }
        return value;
    };
console.log(JSON.stringify(foo, censor)); // undefined

问题2:

请注意以下代码:

var foo = {
    "foundation": "Mozilla",
    "model": "box",
    "week": 45,
    "transport": "car",
    "month": 7
},
    censor = function (key, value) {
        return 2;
    };
console.log(JSON.stringify(foo, censor)); // String: 2

我认为我的代码应该在下面得到字符串,因为“如果您返回一个数字,则与该数字对应的字符串在添加到 JSON 字符串时用作属性的值。” (引自https://developer.mozilla.org/En/Using_native_JSON)。

{"foundation":2,"model":2,"week":2,"transport":2,"month":2}

但我只是得到一个字符串2。为什么?

问题 3:

如果我想得到{"foundation":2,"model":2,"week":2,"transport":2,"month":2},我应该如何更改代码?

非常感谢!

4

1 回答 1

2
  1. foo是一个对象 ( {…})。对象不是字符串。您审查外部对象,因此它永远不会被递归到。
  2. 因为你 return 2forfoo而不是递归进去
  3. 测试它是字符串还是数字(而不是测试它是否不是字符串)然后返回 2
于 2012-04-12T14:53:58.090 回答