所以我试图通过for循环从json对象中获取一些数据并且它一直返回undefined。这是我的代码:
router.get('/', function(req, res, next) {
request('https://api.instagram.com/v1/media/popular?client_id=############', function (error, response, body) {
json = JSON.parse(body);
var popular_tags = [];
for (var key in json['data']){
tag = JSON.stringify(key['tags'])
popular_tags.push(tag)
}
console.log(popular_tags)
res.render('index', {title: body });
});
});
这是我收到的输出:
[ undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined,
undefined ]
然而,当我尝试
时var popular_tags = [];
popular_tags.push(json['data'][0]['tags'])
console.log(popular_tags)
它会打印出我想要的东西。有什么建议吗?
答案 0 :(得分:1)
将行更改为
tag = JSON.stringify(json['data'][key]['tags'])
答案 1 :(得分:1)
当你说
时for (var key in json['data'])
key
正在迭代对象json.data
的属性名称,因此是字符串。因此,key['tags']
为undefined
,因为字符串通常没有属性tags
。事情从那里滚雪球。
一般习语是:
for (var key in json.data) {
if (json.data.hasOwnProperty(key) {
var item = json.data[key];
// ...
}
}
hasOwnProperty
这个东西可以防止某人在你正在迭代的原型中注入某些东西。例如,如果某人做了像Object.prototype.breakAllCode = true
那样愚蠢的事情,那么"breakAllCode"
就会在您迭代的任何内容中显示为key
。