var json = {
"color" : {
"off-white" : {
"inactive" : 0,
"instock" : 5,
"prestock" : 49
},
"red" : {
"prestock" : 50,
"instock" : 10,
"inactive" : 0
}
}
};
在JavaScript中,如果我这样做
for (var col in json.color) {
result += col + " = " + JSON.stringify(json.color[col].prestock)+ "\n";
}
我可以得到"白色"和"红色"以及所有的子文档。
我做了同样的事情,但它不会给我同样的输出。我还能做什么?
要获得"灰白色"和"红色"的输出,我必须
{% for col in Object.keys(json.color) %}
但我无法访问子文档。
如果我做了
{% for col in json.color %}
<li>{{Object.keys(col)}}</li>
我得到
<li>"off-white", "red"</li>
我需要他们分开,就像:
<li>off-white</li>
<li>red</li>
3条答案
按热度按时间stszievb1#
在swig中,你可以不使用
Object.keys
而同时获得key和value:这应该会给予与JavaScript示例中所要求的相同的结果。
rryofs0p2#
在JavaScript中,您应该像这样
//它会给予你一个
这不会返回一个数组,因此您将无法循环通过它。
此外,您可以通过访问
json.color.off-white.inactive
之类的对象来获取inactive
的值vngu2lb83#
因此,要分别显示它们,我认为您需要执行以下操作:
对不起,我想你已经有了颜色键。现在我更新代码,希望能起作用。