问题: 我似乎无法找到一个令人满意的解释,说明为什么 JavaScript map 需要方括号让 JSON.stringify 方法“到达”(?) 到嵌套元素中。我想我遗漏了一些关于 ES6 的东西,或者是 Map 数据类型固有的东西。
我可以将 Map 转换为对象,然后进行字符串化 - 但为什么需要这个额外的步骤?
我的实验:
const blah = new Map();
blah.set('u', {
'something': [{'hey':98}, 56, 'bob']
});
blah.set({
'hey': {'hey': 78}
}, 'what?');
console.log(JSON.stringify(...blah));
//["u",{}]
//I thought this would yield the result of the below console.log
console.log(JSON.stringify([...blah]))
//[["u",{"something":[{"hey":98},56,"bob"]}],[{"hey":{"hey":78}},"what?"]]
//Why are the square brackets needed to stringify and display each element of
//the map?
这article确认了行为,但没有解释为什么会发生。
最佳答案
JSON.stringify(...blah)
是 argument spread ,它采用迭代 map 时获得的值:
['u', {'something': …}]
[{'嘿': …}, '什么?']
并将它们作为不同的参数传递给 JSON.stringify
:
JSON.stringify(
['u', {'something': …}],
[{'hey': …}, 'what?']
);
JSON.stringify
的第二个参数 is supposed to be a replacer function .因为你给了它一些不是函数的东西,它会忽略它。
争论的传播远不是你想要的。您想要的是将映射转换为键/值对数组,这就是 [...blah]
所做的。 Array.from(blah)
会产生同样的效果。
关于javascript - 为什么需要方括号来将 Javascript 中 Map 的所有元素字符串化?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49962462/